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1 General 


1.1 Introduction 


This document describes the specifications of the Ultrastar Archive Hal 0 an HGST 3.5-inch 7200-rpm Serial Attached 
SCSI interface hard disk drive with the following model numbers: 

Table 1 Type and Model# 


Capacity 

Type 

Interface 

Model# 

Description 



Serial Attached SCSI 
4K Native 

HMH7210A0AL4600 

Instant Secure Erase 

10TB 

US7SSJ100 

HMH7210A0AL4601 

TCG(Trusted Computing Group) 



HMH7210A0AL4604 

Secure Erase (Overwrite only) 


1.2 

Glossary 

ESD 

Electrostatic Discharge 

Kbpi 

1,000 bits per inch 

Ktpi 

1,000 tracks per inch 

Gbps 

1,000,000,000 bits per second 

Mbps 

1,000,000 bits per second 

MB/s 

1,000,000 bytes per second 

TB 

1,000,000,000,000 bytes (for Drive Capacity) 

GB 

1,000,000,000 bytes (for Drive Capacity) 

MB 

1,048,576 bytes (for Memory Size) 

KB 

1,024 bytes (for Memory Size) 

S.M.A.R.T. 

Self-Monitoring Analysis and Reporting Technology 

DFT 

Drive Fitness Test 

ADM 

Automatic Drive Maintenance 

1.3 

General caution 


The drive can be damaged by shock or ESD (Electrostatic Discharge). Any damage sustained by the drive after 
removal from the shipping package and opening the ESD protective bag are the responsibility of the user. 


1.4 References 

• SAS Compliance : “Serial Attached Serial SCSI-3 (SAS-3)” 

• SAS Protocol 

> This drive supports Serial SCSI Protocol (SSP) 

> STP (Tunneled SATA) and SMP (Management protocol) protocols are NOT supported 

• Zoned Block Commands (ZBC revision2, Host managed device only, except RC_BASIS) 
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2 General features 

• Host Managed SMR (Shingled Magnetic Recording) 

• Data capacities of 10.0TB 

• Spindle speeds of 7200 RPM 

• Fluid Dynamic Bearing motor 

• Dual Stage Actuator 

• Closed-loop actuator servo 

• Automatic Actuator lock 

• Write Cache 

• Advanced Power Management (APM) 

• S.M.A.R.T. (Self Monitoring and Analysis Reporting Technology) 

• Adaptive zone formatting 

• RVS(Rotational Vibration Safeguard) 

• 256MB Memory 

• Seek time of 8.5 ms in read operation (without Command Overhead) 

• Conventional Zone 1% of Total Capacity 

• Sequential Write Required Zone size of 256MB 

• UnRestricted Sequential Write Required Zone supported (URSWRZ =1) 

• Write Verify for Cold Storage Technology 

• Segmented buffer implementation 

• Automatic Error Recovery procedures for read and write commands 

• Automatic defect reallocation 

• SAS Interface 6/3/1.5Gbps 

• Supports dual-ported operations 

• Supports full duplex operations 

• Sector format of 4096/4112/4160/4224 bytes/sector 

• Back to back write 

• Self diagnostics at power on 

• 64 bit addressing feature 

• SAS-3 compliant 

• ANSI T10 Protection Information (End-to-End) 

• Support TCG Enterprise_A SSC Encryption (specific model only) 

• ZBC revision 2 compliant (Host managed device only, except RC_BASIS) 
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Part 1. Functional specification 
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3 Fixed disk subsystem description 


3.1 Control Electronics 

The drive is electronically controlled by a microprocessor, several logic modules, digital/analog modules, and 
various drivers and receivers. The control electronics performs the following major functions: 

• Controls and interprets all interface signals between the host controller and the drive. 

• Controls read write accessing of the disk media, including defect management and error recovery. 

• Controls starting, stopping, and monitoring of the spindle. 

• Conducts a power-up sequence and calibrates the servo. 

• Analyzes servo signals to provide closed loop control. These include position error signal and estimated 
velocity. 

• Monitors the actuator position and determines the target track for a seek operation. 

• Controls the voice coil motor driver to align the actuator in a desired position. 

• Constantly monitors error conditions of the servo and takes corresponding action if an error occurs. 

• Monitors various timers such as head settle and servo failure. 

• Performs self-checkout (diagnostics). 


3.2 Head disk assembly 

The head disk assembly (HDA) is assembled in a clean room environment and contains the disks and actuator 
assembly. Helium is constantly circulated and filtered when the drive is operational. No venting of the HDA is 
accomplished, as HDA is hermetically sealed. 

The spindle is driven directly by an in-hub, brushless, sensorless DC drive motor. Dynamic braking is used to 
quickly stop the spindle. 


3.3 Actuator 

The read/write heads are mounted in the actuator. The actuator is a swing-arm assembly driven by a voice coil 
motor. A closed-loop positioning servo controls the movement of the actuator. An embedded servo pattern supplies 
feedback to the positioning servo to keep the read/write heads centered over the desired track. 

The actuator assembly is balanced to allow vertical or horizontal mounting without adjustment. 

When the drive is powered off, the actuator automatically moves the head to the actuator ramp outside of the disk 
where it parks. 


HGST Hard Disk Drive OEM Specification 
22 




4 Drive characteristics 


This section describes the characteristics of the drive. 


4.1 Default logical drive parameters 


Table 2 Formatted capacity 


Description 

1 

Physical Layout 





Label capacity 

10TB 

10TB 

10TB 

10TB 

Bytes per Sector 

4096 

4112 

4160 

4224 

Number of Heads 

14 

14 

14 

14 

Number of disks 

7 

7 

7 

7 

Logical Layout 1 





Bytes per Sector 

4096 

4112 

4160 

4224 

Number of Sectors 

2,441,609,216 

2,419,851,264 

2,391,801,856 

2,355,625,984 

Total Logical Data 
Bytes 

10,000,831,348,736 

9,950,428,397,568 

9,949,895,720,960 

9,950,164,156,416 


4.2 Data sheet 


Table 3 Data Sheet 


Description 


Max Data transfer rate (Mbps) 

1900 

Interface transfer rate (MB/s) 

600 

Typ Sustained transfer rate 

Read/Write (MB/s) 

157.3/68.2 

Data buffer size (MB) 

256 

Rotational speed (RPM) 

7,200 

Configurable number of buffer segment Number 

2048max 

Recording density- max (Kbpi) 

1660 

Track density (Ktpi) 

500 

Areal density - max (Gbits/in 2 ) 

830 


Sequential Write Required Zone 


4.3 World Wide Name Assignment 


Table 4 World Wide Name Assignment 


Description 

WWN 

Organizationally Unique Identifier (OUI) 

OOOCCAh (HGST) 

Block Assignment 

24Fh (Thailand) 
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4.4 Drive organization 

4.4.1 Drive Format 

Upon shipment from HGST manufacturing the drive satisfies the sector continuity in the physical format by means 
of the defect flagging strategy described in Section 5 in order to provide the maximum performance to users. 

4.4.2 Cylinder allocation 

Physical cylinder is calculated from the starting data track of 0. It is not relevant to logical CHS. Depending on the 
capacity some of the inner zone cylinders are not allocated. 

Data cylinder 

This cylinder contains the user data which can be sent and retrieved via read/write commands and a spare area for 
reassigned data. 

Spare cylinder 

The spare cylinder is used by HGST manufacturing and includes data sent from a defect location. 

4.4.3 Zone Layout 

The LBAs are divided into ranges called zones. 

The entire capacity of a zoned block device is organized into a set of contiguous, non-overlapping zones. 

Zone size 256MB 

Conventional Zone 1% of Total Capacity 
Sequential write required zone 99% of Total Capacity 


Table 5 Zone Layout 


Description 

1 

Logical Layout 





Bytes per Sector 

4096 

4112 

4160 

4224 

Number of Conventional Zone 

378 

378 

378 

378 

Start LBA 

0 

0 

0 

0 

End LBA 

24,772,607 

24,772,607 

24,772,607 

24,772,607 

Number of Sequential write 
required zone 

36,878 

36,546 

36,118 

35,566 

Start LBA 

24,772,608 

24,772,608 

24,772,608 

24,772,608 

End LBA 

2,441,609,215 

2,419,851,263 

2,391,801,855 

2,355,625,983 

Number of Sectors 

2,441,609,216 

2,419,851,264 

2,391,801,856 

2,355,625,984 


Conventional zone 

^ LBA 0 LBA 24,772,607 | 


Zone 0 Zone 1 

Zone 2 

Zone 377 

Sequential write required zone 

$, .LBA 24,772,608 


LBA 2,441,609,2151 

Zone 378 Zone 379 

Zone 380 

Zone 37255 


Figure 1 Logical Layout example: Number of Block pre Sector 4096 
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4.4.4 Performance characteristics 

Drive performance is characterized by the following parameters: 

• Command overhead 

• Mechanical positioning 

- Seek time 

- Latency 

• Data transfer speed 

• Buffering operation (Look ahead/Write cache) 

All the above parameters contribute to drive performance. There are other parameters that contribute to the 
performance of the actual system. This specification defines the characteristics of the drive, not the characteristics 
of the system throughput which depends on the system and the application. 

4.4.5 Command overhead 

Command overhead is defined as the time required 
From the time 

COMMAND frame 
is sent by host 
To the time 

- DATA frame is sent by device (Read) 

- XFER RDY frame is sent by device (Write) 

- Seek Start (Read cache not hit or Seek) 

The table below gives average command overhead. 


Table 6 Command overhead 


Command type 

(Drive is in quiescent state) 

Typical time (ms) 

Read (Cache not hit) 

0.2 

Read (Cache hit) 

0.2 

Write 

0.5 

Seek 

0.2 
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4.4.6 Mechanical positioning 

4.4.6.1 Average seek time (without command overhead, including settling) 


Table 7 Average seek time 


Command Type 

Typical (ms) 

Max (ms) 

Read 

8.5 

10.0 

Write 

5.5 

6.0 


The terms “Typical” and “Max” are used throughout this specification with the following meanings: 

Typical. The average of the drive population tested at nominal environmental and voltage conditions. 

Max. The maximum value measured on any one drive over the full range of the environmental and voltage 
conditions. (See Section 6.2, “Environment” and Section 6.3, “DC Power Requirements”) 

Read: Full span. 

Write: Conventional zone, not applicable within sequential write required zone as random access is not allowed 

4.4.6.2 Single track seek time (without command overhead, including 

settling) 


Table 8 Single Track Seek Time 


Function 

Typical (ms) 

Max (ms) 

Read 

0.25 

0.35 

Write 

0.35 

0.45 


4.4.6.3 Average latency 

Table 9 Latency Time 


Rotational speed 

Time for a revolution 
(ms) 

Average latency 
(ms) 

7200 RPM 

8.3 

4.16 


4.4.7 Drive ready time 

Table 10 Drive ready time 


Power on to ready 

Typical (sec) 

Maximum (sec) 


20 

30 


Ready 
Power on 


The condition in which the drive is able to perform a media access command (such as read, write) 
immediately 

This includes the time required for the internal self diagnostics. 
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4.4.8 Operating modes 

4.4.8.1 Operating mode descriptions 

Operating mode Description 

Spin-up Start up time period from spindle stop or power down 

Seek Seek operation mode 

Write Write operation mode 

Read Read operation mode 

ldle_A Spindle motor is working normally. Servo system is 

can be received and processed immediately 
ldle_B Spindle rotation at 7200 RPM with heads unloaded 

ldle_C/Standby_Y Spindle rotation at Low RPM with heads unloaded 
Standby_Z Actuator is unloaded and spindle motor is stopped, 

immediately 

Note: Upon power down or spindle stop a head locking mechanism will secure 
position. 

4.4.8.2 Mode transition times 


Mode transition times are shown below. 
Table 11 Mode transition times 


From 

To 

RPM 

Typical Transition time 
(sec) 

Max Transition time 
(sec) 

Standby Z 

Idle A 

0 -> 7200 

15 

30 

Idle A 

Standby Z 

7200 -> 0 

Immediately 

Immediately 

Idle B 

Idle A 

7,200 

1.5 

30 

Idle A 

Idle B 

7,200 

0.7 

30 

IdleC 

Idle A 

6300 -> 7200 

4 

30 


sleeping or waking up. Commands 

Commands can be received 
the heads in the OD parking 
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5 Defect flagging strategy 

Media defects are remapped to the next available sector during the Format Process in manufacturing. The mapping 
from LBA to the physical locations is calculated by an internally maintained table. 


5.1 Shipped format 

• Data areas are optimally used. 

• No extra sector is wasted as a spare throughout user data areas. 

• All pushes generated by defects are absorbed by the spare tracks of the inner zone. 


N 

N+1 

defect 

N+2 

defect 

N+3 


skip skip 


Figure 2 PList physical format 

Defects are skipped without any constraint, such as track or cylinder boundary. The calculation from LBA to 
physical is done automatically by internal table. 
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6 Specification 


6.1 Electrical interface 

6.1.1 Connector location 

Refer to the following illustration to see the location of the connectors. 



Figure 3 Connector location 

6.1.1.1 Signal connector 

The drive uses the standard 29 pin Serial Attached SCSI (SAS) connector which conforms to the mechanical 
requirements of SFF 8482. The connector is expected to be used in an environment which uses a common 
connector structure for racking disk drives in a cabinet. The connector allows for plugging a drive directly into a 
backplane by providing the necessary electrical connection. Mechanical stability and device retention must be 
provided by a mechanism outside the drive. 
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6.1.2 29 pin Serial Attached SCSI (SAS) Connector Definition 


Diagram of top and bottom of connector showing pinouts. 



Figure 4 SAS Connector 


Table 12 29-pin Connector Signal Definition 


Pin No. 

Signal 

Description 

SI 

GND 

GND for SAS Primary Port 

S2 

RP+ 

SAS Primary Port Receive (Positive) signal 

S3 

RP- 

SAS Primary Port Receive (Negative) signal 

S4 

GND 

GND for SAS Primary Port 

S5 

TP- 

SAS Primary Port Transmit (Negative) signal 

S6 

TP+ 

SAS Primary Port Transmit (Positive) signal 

S7 

GND 

GND for SAS Primary Port 

S8 

GND 

GND for SAS Secondary Port 

S9 

RS+ 

SAS Secondary Port Receive (Positive) signal 

S10 

RS- 

SAS Secondary Port Receive (Negative) signal 

S11 

GND 

GND for SAS Secondary Port 

S12 

TS- 

SAS Secondary Port Transmit (Negative) signal 

S13 

TS+ 

SAS Secondary Port Transmit (Positive) signal 

S14 

GND 

GND for SAS Secondary Port 

PI 

Vendor Spec 

NOT USED (Pins P1-P3 tied internally) 

P2 

Vendor Spec 

NOT USED (Pins P1-P3 tied internally) 

P3 

POWER DISABLE 

Power disable pin for +5V/+12V 

P4 

GND 

GROUND 

P5 

GND 

GROUND 

P6 

GND 

GROUND 

P7 

+5V-Charge 

Pre-charge pin for +5V 

P8 

+5V 

+5V power supply input 

P9 

+5V 

+5V power supply input 

P10 

GND 

GROUND 

P11 

READY LED 

READY LED output 

P12 

GND 

GROUND 

P13 

+12V=Charge 

Pre-charge pin for +12V 

P14 

+12V 

+12V power supply input 

P15 

+12V 

+12V power supply input 
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6.1.3 Voltage and Ground Signals 

The 12V and 5V contacts provide all of the voltages required by the drive. The two voltages share a common 
ground plane to which all of the ground contacts are connected. 

6.1.4 Ready LED output 

The drive provides an open-drain driver with 15mA of current sink capability to the Ready LED Output signal. The 
cathode of the LED should be connected to this signal. The LED and the current-limiting resistor must be provided 
by the enclosure 
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6.2 Environment 

6.2.1 Temperature and humidity 


Table 13 Temperature and humidity 


Operating conditions | 

Temperature 

Relative humidity 

Maximum wet bulb temperature 

Maximum temperature gradient 

Altitude 

10 to 60 °C 

5 to 90% non-condensing 

29.4°C non-condensing 

20°C/Hour 
-300 to 3,048 m 

Non-Op conditions j 

Temperature 

Relative humidity 

Maximum wet bulb temperature 

Maximum temperature gradient 

Altitude 

-40 to 70 °C (Storage 0 to 70 °C) 

5 to 95% non-condensing 

35°C non-condensing 

30°C/Hour 

-300 to 12,000 m (Inside dashed-dotted line of Figure 5) 


Notes: 

1. The system is responsible for providing sufficient ventilation to maintain a surface temperature below 65 V at 
the center of the top cover of the drive. 

2. Non condensing conditions should be maintained at any time. 

3. Maximum storage period within shipping package is one year. 
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Figure 5 Limits of temperature and altitude 
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Figure 6 Limits of temperature and humidity 

6.2.2 Corrosion test 

The drive shows no sign of corrosion inside and outside of the hard disk assembly and is functional after being 
subjected to seven days at 50°C with 90% relative humidity. 

6.2.3 Atmospheric condition 

Environments that contain elevated levels of corrosives (e.g. hydrogen sulfide, sulfur oxides, or hydrochloric acid) 
should be avoided. Care must be taken to avoid using any compound/material in a way that creates an elevated 
level of corrosive materials in the atmosphere surrounding the disk drive. Care must also be taken to avoid use of 
any organometallic (e.g. organosilicon or organotin) compound/material in a way that creates elevated vapor levels 
of these compounds/materials in the atmosphere surrounding the disk drive. 
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6.3 DC power requirements 

The following voltage specification applies at the drive power connector. Connections to the drive should be made 
in a safety extra low voltage (SELV) circuit. There is no power on or power off sequencing requirement. 

Adequate secondary over-current protection is the responsibility of the system. 

6.3.1 Input voltage 


Table 14 Input voltage 


Input voltage 

During run 
and spin up 

Absolute max 
spike voltage 

Supply rise 
time 

+5 Volts Supply 

5V ± 5% 

-0.3 to 5.5V 

0 to 200ms 

+12 Volts Supply 

12V ±5% 

-0.3 to 15.0V 

0 to 400ms 


Caution: To avoid damage to the drive electronics, power supply voltage spikes must not exceed specifications. 
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6.3.2 Power supply current (typical 1 ) 

Table 15 Power supply current (SAS) 


(SAS) 

Serial Attached SCSI @6Gb/sec 

10TB Model 




10/Sec 

Current 
+5V Amp 

Current 
+12V Amp 

Power 

Watts 

Start up Peak DC 

[1] 


1.48 


Start up Peak AC 


0.99 

2.02 


ldle_0 Ave. 


0.40 

0.32 

5.9 | 

Idle Ripple 

[2] 

0.27 

0.39 



Random RW 4KB Qd=1 Peak 
Random RW 4KB Qd=1 Ave. 


Sequential Read Peak 
Sequential Read Ave. 
Sequential Write Peak 
Sequential Write Ave. 

Sequential Read Peak 
Sequential Read Ave. 
Sequential Write Peak 
Sequential Write Ave. 

BMS Peak 
BMS Ave. 


34 | [4] 


Q 37 | 


- Conventional zone 


0.33 | 


0 35 | 7 3 | 


Power Save Mode 

Current 


Power 

Watts Saved 

Recovery [1] 

(PHY state: Active) 

+5V Amp 

+12V Amp 

Watts 

[5] 

12V DC peak 

12V AC peak 

ldle_A 

0.38 

0.31 

5.7 

0.2 



ldle_B 

0.32 

0.23 

4.3 

1.6 



ldle_C 

0.32 

0.18 

3.7 

2.1 

0.97 

1.80 

StandbyJY 

0.32 

0.18 

3.7 

2.1 

0.97 

1.80 

Standby_Z 

0.31 

0.003 

1.6 

4.3 

1.44 

1.82 


Notes 

Reference data, sample number = lOHDDs, DE temp. = 40degC (25degC for Start up), WCE=1 

[1] 200mS windowed average 

[2] Pk to Pk BWL @20MHz 

[3] Max transfer rate 

[4] Random zone Read and Write in partially selected zone 

[5] Saved watts compared to ldle_0 
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6.3.3 Power supply generated ripple at drive power connector 


Table 16 Power supply generated ripple at drive power connector 



Maximum (mV pp) 

MHz 

+5V DC 

200 

0-10 

+12V DC 

250 

0-10 


During drive start up and seeking 12-volt ripple is generated by the drive (referred to as dynamic loading). If the 
power of several drives is daisy chained together, the power supply ripple plus the dynamic loading of the other 
drives must remain within the above regulation tolerance. A common supply with separate power leads to each 
drive is a more desirable method of power distribution. 

To prevent external electrical noise from interfering with the performance of the drive, the drive must be held by four 
screws in a user system frame which has no electrical level difference at the four screws position and has less than 
±300 millivolts peak to peak level difference to the ground of the drive power connector. 

6.3.4 Power Consumption Efficiency 


Table 17 Power consumption efficiency 


Power Consumption 

W/TB 

0.57 

Efficiency at Idle 

W/GB 

0.00057 
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6.4 Reliability 

6.4.1 Data integrity 

No more than one sector is lost at Power loss condition during the write operation when the write cache option is 
disabled. If the write cache option is active, the data in write cache will be lost. To prevent the loss of customer 
data, it is recommended that the last write access before power off be issued after setting the write cache off. 

6.4.2 Cable noise interference 

To avoid any degradation of performance throughput or error rate when the interface cable is routed on top or 
comes in contact with the HDA assembly, the drive must be grounded electrically to the system frame by four 
screws. The common mode noise or voltage level difference between the system frame and power cable ground or 
AT interface cable ground should be in the allowable level specified in the power requirement section. 

6.4.3 Load/Unload 

The product supports a minimum of 600,000 normal load/unloads in a 40° C environment. 

Load/unload is invoked by transition of the HDD's power mode. (Chapter 4.5.4 Operating modes) 

Idle <-> unload idle 
Idle <-> Low rpm idle 

6.4.4 Start/stop cycles 

The drive withstands a minimum of 50,000 start/stop cycles in a 40° C environment and a minimum of 10,000 
start/stop cycles in extreme temperature or humidity within the operating range. 

6.4.5 Preventive maintenance 

None 

6.4.6 Data reliability 

Probability of not recovering data is 1 in 10 15 bits read. 

LDPC on the fly/ offline data correction 

• 600 bit LDPC 

• This implementation recovers maximum 330 bits single burst error by on the fly correction and maximum 450 
bits single burst error by offline correction 

6.4.7 Required Power-Off Sequence 

The required Host sequence for removing power from the drive is as follows: 

Step 1: Issue one of the following commands. 

Stop Unit 

Step 2: Wait until the Command Complete status is returned. In a typical case 350 ms are required for the 
command to finish completion; however, the Host time out value needs to be 30 seconds 
considering error recovery time. 

Step 3: Terminate power to HDD. 
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6.5 Mechanical specifications 

6.5.1 Physical dimensions 



*1 101.6+0.25 IS APPLIED FOR HATCHED AREA ONLY. 


Figure 7 Top and side views and mechanical dimensions 
All dimensions are in millimeters. 
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All dimensions in the above figure are in millimeters. 

The following table shows the physical dimensions of the drive. 
Table 18 Physical Dimensions 


Height (mm) 

Width (mm) 

Length (mm) 

Weight (grams) 

26.1 MAX 

101.6 ±0.25 

147 MAX 

650 MAX 
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6.5.2 Connector locations 


41 .13 REF 



Figure 9 Connector locations 
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6.5.3 Drive mounting 

The drive will operate in all axes (6 directions). Performance and error rate will stay within specification limits if the 
drive is operated in the other orientations from which it was formatted. 

For reliable operation, the drive must be mounted in the system securely enough to prevent excessive motion or 
vibration of the drive during seek operation or spindle rotation, using appropriate screws or equivalent mounting 
hardware. 

The recommended mounting screw torque is 0.6 -1.0 Nm (6-10 Kgf.cm). 

The recommended mounting screw depth is 3.8mm maximum for bottom and 6.1 mm maximum for horizontal 
mounting. 

Drive level vibration test and shock test are to be conducted with the drive mounted to the table using the bottom 
four screws. 

6.5.4 Heads unload and actuator lock 

Pleads are moved out from disks (unload) to protect the disk data during shipping, moving, or storage. Upon 
power down, the heads are automatically unloaded from disk area and the locking mechanism of the head actuator 
will secure the heads in unload position. 
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6.6 Vibration and shock 

All vibration and shock measurements recorded in this section are made with a drive that has no mounting 
attachments for the systems. The input power for the measurements is applied to the normal drive mounting points. 

6.6.1 Operating vibration 

6.6.1.1 Random vibration (Linear) 

The test is 30 minutes of random vibration using the power spectral density (PSD) levels shown below in each of 
three mutually perpendicular axes. The disk drive will operate without non-recoverable errors when subjected to the 
below random vibration levels. 

Table 19 Random vibration PSD profile break points (operating) 


Frequency 

5 Hz 

17 Hz 

45 Hz 

48 Hz 

62 Hz 

65 Hz 

150 Hz 

200 Hz 

500 Hz 

RMS 

(m/sec 2 ) 

[(m/sec 2 ) 2 /Hz] 

1.9 x 
10E-3 

1.1 X 
10E-1 

1.1 X 
10E-1 

7.7 x 
10E-1 

7.7 x 
10E-1 

9.6 x 
10E-2 

9.6 x 
10E-2 

4.8 x 
10E-2 

4.8 x 
10E-2 

6.57 


The overall RMS (root mean square) level is 6.57 m/sec 2 (0.67 G). 

6.6.1.2 Swept sine vibration (Linear) 


The drive will meet the criteria shown below while operating in the specified conditions: 

• No errors occur with 4.9 m/sec 2 (0.5 G) 0 to peak, 5 to 300 to 5 Hz sine wave, 0.5 oct/min sweep rate with 3- 
minute dwells at two major resonances 

• No data loss occurs with 9.8 m/sec 2 (1 G) 0 to peak, 5 to 300 to 5 Hz sine wave, 0.5 oct/min sweep rate with 3- 
minute dwells at two major resonances 

6.6.1.3 Random vibration (Rotational) 

The drive will meet the criteria shown below while operating in the specified conditions: 

• Less than 20% Performance degradation 

• The overall RMS (Root Mean Square) level of vibration is 12.5Rad/sec A 2. PSD profile is shown below. 


Table 20 Random vibration (Rotational) PSD profile break points 


Frequency 

20 Hz 

100 Hz 

200 Hz 

800 Hz 

1000 Hz 

1500 Hz 

1700 Hz 

2000 Hz 

RMS 

(Rad/s 2 ) 

[(Rad/s 2 ) 

2 /Hz] 

1.90E 

-02 

1.90E 

-02 

1.87E 

-01 

1.87E 

-01 

5.33E 

-02 

7.70E 

-03 

4.00E 

-03 

4.00E 

-03 

12.5 
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6.6.2 Nonoperating vibration 

The drive does not sustain permanent damage or loss of previously recorded data after being subjected to the 
environment described below 

6.6.2.1 Random vibration 

The test consists of a random vibration applied for each of three mutually perpendicular axes with the time duration 
of 10 minutes per axis. The PSD levels for the test simulate the shipping and relocation environment shown below. 
The overall RMS (Root Mean Square) level of vibration is 10.2 m/sec 2 (1.04 G). 

Table 21 Random vibration PSD profile break points (nonoperating) 


Frequency 

2 Hz 

4 Hz 

8 Hz 

40 Hz 

55 Hz 

70 Hz 

200 Hz 

[(m/sec 2 ) 2 /Hzj 

0.096 

2.89 

2.89 

0.289 

0.962 

0.962 

0.096 


6.6.2.2 Swept sine vibration 

• 19.6 m/sec 2 (2 G) (Zero to peak), 5 to 500 to 5 Hz sine wave 

• 0.5 oct/min sweep rate 

• 3 minutes dwell at two major resonances 
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6.6.3 Operating shock 

The drive meets the following criteria while operating in the conditions described below. The shock test consists of 
10 shock inputs in each axis and direction for total of 60. There must be a delay between shock pulses long enough 
to allow the drive to complete all necessary error recovery procedures. 

• No error occurs with a 98.1 m/sec 2 (10 G) half-sine shock pulse of 11 ms duration. 

• No data loss occurs with a 294 m/sec 2 (30 G) half-sine shock pulse of 4 ms duration. 

• No data loss occurs with a 686 m/sec 2 (70 G) half-sine shock pulse of 2 ms duration. 

6.6.4 Nonoperating shock 

The drive will operate without non-recoverable errors after being subjected to shock pulses with the following 
characteristics. 

6.6.4.1 Trapezoidal shock wave 

• Approximate square (trapezoidal) pulse shape 

• Approximate rise and fall time of pulse isl ms 

• Average acceleration level is 490 m/sec 2 (50 G). (Average response curve value during the time following the 1 
ms rise time and before the 1 ms fall with a time "duration of 11 ms") 

• Minimum velocity change is 4.23 m/sec 

6.6.4.2 Sinusoidal shock wave 

The shape is approximately half-sine pulse. The figure below shows the maximum acceleration level and duration. 
Table 22 Sinusoidal shock wave 


Acceleration level (m/sec 2 ) 

Duration (ms) 

2940(300G) 

1 

1470(150G) 

11 


6.6.5 Nonoperating Rotational shock 

All shock inputs shall be applied around the actuator pivot axis. 
Table 23 Rotational Shock 


Duration 

Rad/sec 2 

1 ms 

30,000 

2 ms 

20,000 
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6.7 Acoustics 

The upper limit criteria of the octave sound power levels are given in Bels relative to one picowatt and are shown in 
the following table. The sound power emission levels are measured in accordance with ISO 7779. 

Table 24 Sound power levels 


Mode 

7200rpm (Typical / Max) 

Idle 

2.0/2.5 

Operating 

3.6/4.0 


Mode definition: 

Idle mode. The drive is powered on, disks spinning, track following, unit ready to receive and respond to 

interface commands. 

Operating mode. Continuous random cylinder selection and seek operation of the actuator with a dwell time at 
each cylinder. The seek rate for the drive is to be calculated as shown below: 

• Dwell time = 0.5 x 60/RPM 

• Seek rate = 0.4 / (Average seek time + Dwell time) 


6.8 Identification labels 

The following labels are affixed to every drive shipped from the drive manufacturing location in accordance with the 
appropriate hard disk drive assembly drawing: 

• A label containing the HGST logo, the HGST part number, and the statement “Made by HGST, Ltd.” or HGST 
approved equivalent 

• A label containing the drive model number, the manufacturing date code, the formatted capacity, the place of 
manufacture, UL/CSA/TUV/CE/RCM mark logos and WEEE/China RoHS logos 

• A bar code label containing the drive serial number 

• A label containing the jumper pin description 

• A user designed label per agreement 

The above labels may be integrated with other labels. 
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6.9 Safety 

6.9.1 UL and CSA standard conformity 

The product is qualified per UL60950-1 : Second Edition and CAN/CSA-C22.2 No.60950-1-07 Second Edition, for 
use in Information Technology Equipment including Electric Business Equipment. 

The UL recognition or the CSA certification is maintained for the product life. 

The UL and C-UL recognition mark or the CSA monogram for CSA certification appear on the drive. 

6.9.2 German Safety Mark 

The product is approved by TUV on Test requirement: EN60950-1 : 2006+A11 but the GS mark is not applicable to 
internal devices such as this product. 

6.9.3 Flammability 

The printed circuit boards used in this product are made of material with the UL recognized flammability rating of V- 
1 or better. The flammability rating is marked or etched on the board. All other parts not considered electrical 
components are made of material with the UL recognized flammability rating of V-2 minimum basically. 

6.9.4 Safe handling 

The product is conditioned for safe handling in regards to sharp edges and corners. 

6.9.5 Substance restriction requirements 

The product complies with the Directive 2002/95/EC of the European Parliament on the restrictions of the use of the 
certain hazardous substances in electrical and electronic equipment (RoHS) and with Halogen free requirements 
based on the electronics industry standard, IEC 61249-2-21 (http://www.iec.ch/) . 

6.9.6 Secondary circuit protection 

Spindle/VCM driver module includes 12 V over current protection circuit. 
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6.10 Electromagnetic compatibility 

When installed in a suitable enclosure and exercised with a random accessing routine at maximum data rate, the 
drive meets the following worldwide EMC requirements: 

• United States Federal Communications Commission (FCC) Rules and Regulations (Class B), Part 15. (A 6 dB 
buffer shall be maintained on the emission requirements). 

• European Economic Community (EEC) directive number 76/889 related to the control of radio frequency 
interference and the Verband Deutscher Elektrotechniker (VDE) requirements of Germany (GOP).Spectrum 
Management Agency (SMA) EMC requirements of Australia. The SMA has approved RCM Marking for HGST. 

6.10.1 CEMark 

The product is declared to be in conformity with requirements of the following EC directives under the sole 
responsibility of HGST, Ltd: 

Council Directive 2004/108/EC on the approximation of laws of the Member States relating to electromagnetic 
compatibility. 

6.10.2 RCM Mark 

The product complies with the following Australian EMC standard: 

“Information technology equipment - Radio disturbance characteristics - Limits and methods of measurement, 

EN 55022 : 2010(AS/NZS CISPR 22 : 2009 / A1 : 2010 Comparable)” 

6.10.3 BSMI Mark 

The product complies with the Taiwan EMC standard “Limits and methods of measurement of radio disturbance 
characteristics of information technology equipment, CNS 13438 Class B.” 

6.10.4 KC Mark 

The product complies with the Korea EMC standard. The regulation for certification of information and 
communication equipment is based on “Telecommunications Basic Act” and “Radio Waves Act” Korea EMC 
requirement are based technically on CISPR22 measurement standards and limits. KC standards are likewise 
based on I EC standards. 
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Part 2. Interface specification 
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7 SAS Attachment 


This section defines some basic terminology and describes the behavior of the drive when attached to a Serial 
attached SCS/(i.e. SAS) domain. 


7.1 General 

This section introduces some of the terminology that is used in describing Serial Attached SCSI (i.e. SAS). 

SAS is logically a bi-directional, point to point serial data channel that leverages the SCSI protocol set. Nodes are 
physically connected via a Port. 

Ports may be connected point-to-point via SAS expanders, to form a complex switching network, referred to as a SAS 
domain. 

SAS is defined in terms of a hierarchy of functions or 'protocol layers'. This discussion will focus in on the aspects of 
SAS that are relevant to this product. 

• SCSI Application Layer - Clause 10 

• SSP Transport Layer (Serial SCSI Protocol) - Clause 9 

• SAS Port Layer - Clause 8 

• SSP Link Layer - Clause 7 

• SAS PHY Layer - Clause 6 

• SAS Physical Layer - Clause 5 

All layers are defined in the following ANSI standard. 

• "SAS Protocol Layer (SPL-3)" 

In addition, this drive claims compliance with the following ANSI standards. 

• SCSI Architecture Model (SAM-5) 

• SCSI Block Commands (SBC-3) 

• Zoned Block Commands (ZBC revision2, Sequential write required zone only, except RC_BASIS) 
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7.2 SAS Features 

The following SAS features are supported by the Drive. 
• SAS Compliance 

- "Serial Attached SCSI -3 (SAS-3)" 



SAS Protocol 

- This drive supports Serial SCSI Protocol (SSP). 

- STP (Tunneled SATA) and SMP (Management protocol) protocols are NOT supported. 
SAS Dual Ported Operation 

- Single PHY ports (i.e. Narrow port. Wide Port NOT supported) 

- Ports function independently with separate firmware controls 

- Multiple DMA engines capable of accessing either port 

- Maximum outstanding credit of four per port 
Physical Link Rates 

- G1 (1.5 Gbps), G2 (3.0 Gbps) and G3 (6.0 Gbps) supported 

- Largely Automated OOB and speed negotiation sequences 

- Optional Support for the hot-plug timeout in hardware 
Partial support for Disconnect/Reconnect Mode Page (0x02) 

- Maximum Connect Time Limit - SUPPORTED 

- Bus Inactivity Time Limit - NOT SUPPORTED 

- Maximum Burst Size - SUPPORTED 

- First Burst Size - NOT SUPPORTED 
Others... 

- Connection Rate Matching 

- Hard Reset primitive sequence detection and validation in hardware 

- Support for NOTIFY (Enable Spin-up) and NOTIFY (Power Loss Expected) 

- Hashed WWN validation in hardware 

- extended CDB support 
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7.3 SAS Names and Identifiers 

In SAS, device and port names are worldwide unique names within a transport protocol. Port identifiers are the values 
by which ports are identified within a domain, and are used as SAS addresses. Phy identifiers are unique within a 
device. 

Table 25 Names and identifiers 


Object 

SAS Implementation 

Port Identifier 

SAS address 

Port Name 

Not defined 

Device Name 

SAS address 

Phy Identifier 

Phy identifier 


Where the SAS Address format is defined by ANSI as follows: 
Table 26 IEEE Registered Name format 


Byte 

Bit 

7 | 6 | 5 | 4 

3 | 2 | 1 | 0 

0 

NAA (5h) 

(MSB) 

1 

IEEE Company ID 

2 

3 

(LSB) (MSB) 

4 

Vendor Specific Identifier 
(LSB) 

5 

6 

7 


The SAS Device Name is a unique SAS address worldwide name. This device name is reported through the SCSI 
Vital Products Data. 

Each of the two SAS ports also has a unique SAS address worldwide name. These port identifiers are reported in the 
IDENTIFY Address frame and are used as source and destination addresses in the OPEN address frame. They are 
also reported through the SCSI Vital Products Data. 

Since this drive is one device with two ports it has three SAS addresses. All SAS Addresses are in 64-bit IEEE 
Registered Name format, as illustrated in Table 27 Name Address Authority field. 


Table 27 Name Address Authority field 


Field 

Description 

OUI 

Organizationally Unique Identifier (24 bits). Canonical form means that 


each byte is stored in “bit reversed” order. 

Block Assignment 

Block assignment within HGST, a Western Digital Company 

Object 

Device Name/Port Identifier 


00b 

Logical Unit Name 


01b 

Portl 


10b 

Port 2 


11b 

Target Device Name 

S/N 

Sequentially increasing drive serial number assigned at manufacturing. 
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7.4 Spin up 

The drive supports the Active Wait, Active, and Stopped states specified by the SAS standard. After power on, the 
drive enters the Active Wait state. The Drive will not spin up it's spindle motor after power on until it receives a NOTIFY 
(Enable Spinup) primitive on either port to enter the Active state. If a NOTIFY (Enable Spinup) primitive is received 
prior to receiving a StartStop Unit command with the Start bit set to one, spin up will begin immediately. For SAS, this 
is analogous to auto-spinup function in legacy SCSI. This provision allows the system to control the power spikes 
typically incurred with multiple drives powering on (and spinning up) simultaneously. 

If a StartStop command with the Start bit set to one is received prior to receiving a NOTIFY (Enable Spinup), the 
Drive will not start it’s spindle motor until Notify (Enable Spinup) is received on either port. Successful receipt of a 
NOTIFY (Enable Spinup) is a prerequisite to spin up. 

If the StartStop Unit command with the Start bit set, also has the immediate bit set, status will be returned prior to 
actually spinning up the motor, but the actual act of spinning up the motor is deferred until receipt of the NOTIFY 
(Enable Spinup) primitive. If a media access command is received after sending immediate Status and prior to 
receiving a NOTIFY (Enable Spinup), the Drive will terminate the command with CFIECK CONDITION status with a 
sense key of NOT READY and an additional sense code of LUN NOT READY, NOTIFY (ENABLE SPINUP) 
REQUIRED. If a media access command is received after receiving the NOTIFY (Enable Spinup) primitive and before 
the drive is finished spinning up, the Drive will terminate the command with CHECK CONDITION status with a sense 
key of LUN NOT READY and an addition sense code of LUN IS IN THE PROCESS of BECOMING READY. 



Figure 10 Spinup 
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7.5 PHY Layer 

The Phy layer defines 8b10b coding and OOB signals. The Phy layer is the interface between the link layer and the 
physical layer. This section describes Phy Layer behaviors of the Drive. For a complete description of SAS Phy Layer, 
please see the ANSI specification, SAS 1.1. 

7.5.1 Link Reset Sequence 

The Link Reset Sequences for SAS are defined in the SAS 2 ANSI specification and shown below. As show in the 
diagram, a Phy Reset sequence, consists of an OOB sequence, followed by speed negotiations. Link Reset 
Sequences will always include a PHY Reset Sequence, followed by an Identification Sequence. Inclusion of a Hard 
reset sequence is optional. If Hard Reset is performed, it will be preceded by a Phy Reset sequence, and will be 
followed by Phy Reset/Identification sequences. 


SAS T,me 


Link Reset sequence 

Phy Reset sequence 

Identification sequence 

OOB sequence | 

Speed Negotiation 

SAS w/Hard Reset 

sequence 

Tin 

ie 

Link Reset sequence with hard error 


Phy Reset sequence 

Hard Reset sequence 

Phy Reset sequence 

Identification sequence 








Figure 11 Link Reset Sequence 
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7.5.2 Hard Reset 

A Hard Reset sequence on a port will not affect the other port, but the outstanding commands on the other port will 
be aborted due to the LUN reset associated with the Hard Reset. The effect of a Hard Reset will be similar to a Power 
on Reset, and will result in the re-initialization of all Drive resources. The first command issued from every initiator on 
the port that received the Hard Reset will result in a CHECK CONDITION with a sense key of UNIT ATTENTION and 
an additional sense code of SCSI BUS RESET OCCURRED. The first command issued from every initiator on the 
other port will result in a CHECK CONDITION and an additional sense code of BUS DEVICE RESET OCCURRED. 

A Hard Reset Sequence will never be issued by the Drive. A link reset will be initiated by the drive on the affected 
port upon completion of Hard Reset processing. 

7.5.3 SAS OOB (Out of Band) 

Out of band (OOB) signals are low-speed signal patterns detected by the Phy that do not appear in normal data 
streams. They consist of defined amounts of idle time followed by defined amounts of burst time. During the idle time, 
D.C. idle is transmitted. During the burst time, ALIGN (0) primitives are transmitted repeatedly. The signals are 
differentiated by the length of idle time between the burst times. 

As a SAS compliant device, the Drive uses three OOB signals: COMINIT/COMRESET and COMWAKE and 
COMSAS.OOB operations are beyond the scope of this specification. Please refer to the ANSI SAS 2 specification 
for more details. 

The drive will initiate OOB by sending COMINITs, under the following conditions: 

- POR 

- loss of sync 

- Identify timeout 
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7.5.4 SAS Speed Negotiation 

The Drive supports G1 (1.5 Gbps), G2 (3.0 Gbps), and G3 (6.0 Gbps) negotiation speeds. The default maximum 
negotiation rate is G3 speed (per byte 32 in the Phy Control and Discover Mode Page 19 subpage 1). Drive is SAS2 
device and supports SNW-1, SNW-2, and SNW-3 speed negotiation with Phy capabilities exchange, and training 
(Train-SNW). Phy capabilities is defined in table below: 


Phy Capabilities: 

Table 28 SAS Speed Negotiation 


Byte 

Bit 

7 

6 

5 

4 

3 

2 

1 1 0 

0 

Start =1b 

TX SSC 
Type = Ob 

Reserved 

Requested Logical Link Rate = Oh 

1 

G1 Without 
SSC=1b 

G1 With 
SSC=0b 

G2 Without 
SSC=1b 

G2 With 
SSC=0b 

G3 Without 
SSC=1b 

G3 With 
SSC=0b 

Reserved 

2 

Reserved 

3 



Reserved 



Parity 


• Start bit is 1 to indicate the beginning of the Phy capabilities 

• TX SSC Type bit is set to 0 to indicate that Phy’s transmitter uses down spreading SCC when is enabled (e.g. 
the phy is a SAS phy). 

• Request Logical Link Rate field is 0 to indicate that drive does not support multiplexing 

• G1 Without SSC bit set to 1 indicates that drive supports G1 (1.5 Gbps) without SSC 

• G2 Without SSC bit set to 1 indicates that drive supports G2(3.0 Gbps) without SSC 

• G3 Without SSC bit set to 1 indicates that drive supports G3(6.0 Gbps) without SSC 

• G1 With SSC bit set to 1 indicates that drive supports G1 (1.5 Gbps) with SSC 

• G2 With SSC bit set to 1 indicates that drive supports G2(3.0 Gbps) with SSC 

• G3 With SSC bit set to 1 indicates that drive supports G3(6.0 Gbps) with SSC 

• Parity bit is set to 1 for even parity of the total number of SNW-3 phy capabilities, including Start bit. 

Training is based on the highest untried commonly supported settings on the exchanged SNW-3 supported settings 
bits. If a Train-SNW is invalid and there are additional, untried, commonly supported settings exchanged during SNW- 
3, then a new Train-SNW will be performed based on the next highest untried, commonly supported settings. Table 
29 defines the priority of the supported settings bits. 

Table 29 Supported Settings Bit Priorities 


Priority 

Bit 

Highest 

G3 With SSC bit 


G3 Without SSC bit 


G2 With SSC bit 


G2 Without SSC bit 


G1 With SSC bit 

Lowest 

G3 Without SSC bit 
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7.5.5 PHY Error Handling 

This section defines the PHY layer error handling of the drive. 


Table 30 PHY Layer Error Handling 


Error 

Error Handling Procedure 

Link Reset 

After POR or Hard Reset, the drive initiates link reset by transmitting exactly 1 
COMINIT. For other resets, the drive does not initiate Link Reset. 

COMINIT Timeout 

If COMINIT or COMSAS is not received before the ’’Hot Plug Timeout" period 
expires, the drive continues to transmit DC zero and wait for COMINIT/COMSAS. 
Firmware is notified. 

This is not considered an error. 

COMSAS Timeout 

If COMINIT is detected, COMSAS is transmitted, and COMSAS is not received 
before the COMSAS Detect Timeout timer expires, firmware is notified and the drive 
continues to transmit DC zero and wait for COMINIT. 

Speed Negotiation Errors 

If speed negotiation fails with no match, or if the drive fails retrying the matched link 
rate, firmware is notified and the drive continues to transmit DC zero and wait for 
COMINIT. If the match link rate retry fails, the Phy Reset Problem counter is 
incremented (Log Page 0x18). 

Loss of Sync 

If the drive loses DWORD sync long enough for the loss of sync timer to expire, 
firmware is notified and the drive transmits a COMINIT to initiate a new link reset. 

The Loss of DWORD sync counter is incremented (Log Page 0x18). 

Disparity/Invalid DWORD 
Error 

If a disparity error or an invalid DWORD is detected by the drive, the Invalid 

DWORD Count is incremented (Log Page 0x18). The Running Disparity Error Count 
in Log Page 0x18 is not used 
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7.6 Link Layer 

The SAS link layer defines primitives, address frames, and connections. The Link layer is the interface between the 
Port layer and the Phy layer. This section describes Link Layer behaviors of the Drive. For a complete description of 
SAS Link Layer, please see the ANSI specification, SAS 1.1. 

7.6.1 Address Frames 

Address frames are used for the identification sequence and for connection requests and are only sent outside 
connections. The Address Frame format is defined below: 

Table 31 Address Frame Format 


Byte 

Bit 

7 

6 5 4 

3 2 1 0 

0 

Rsvd 

Device Type 

Address Frame Type 

1-27 

Frame Type Dependent bytes 

28-31 

CRC 


• The ADDRESS FRAME TYPE field indicates the type of address frame and is defined in Table 32. This field 
determines the definition of the frame type dependent bytes. 

Table 32 Frame type: 


Value 

Address Frame Type Description 

0000b 

IDENTIFY: Identification Sequence 

0001b 

OPEN: Connection Request 

Others 

RESERVED 
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7.6.1.1 Identify Address Frame 

The IDENTIFY address frame format is used for the identification sequence. The IDENTIFY address frame is sent 
after the phy reset sequence completes. The Identify Address Frame format is defined as follows: 

Table 33 Identify Address Frame 


Byte 

Bit 

7 

6 | 5 | 4 

3 | 2 | 1 | 0 

0 

Rsvd 

Device Type = 1 

Address Frame Type = 0 

1 

Reserved 

Reason 

2 

Reserved 

SSP Initiator 
Port=0b 

STP Initiator 
Port=0b 

SMP Initiator 
Port=0b 

Rsvd 

3 

Reserved 

SSP Target 
Port=1b 

STP Target 
Port=0b 

SMP Target 
Port=0b 

Rsvd 

4-11 

Device Name 

12-19 

SAS Address 

20 

PHY Identifier 

21 

Reserved 

Inside ZPSDS 
Persistent=0b 

Requested 

Inside 

ZPSDS=0b 

Break_Reply 

Capable=1b 

22-27 

Reserved 

28-31 

CRC 


• Device Type: set to 001b to indicate that this drive is an "End Device". 

• Address Frame Type: set to 00b to indicate that this is an IDENTIFY. 

• Reason: field indicates the reason for link reset sequence as defined in Table 33 

• Initiator Port bits: set to 000b since this device is a target device only 

• Target Port bits: set to 100b since this device is a SSP target device only 

• Device Name: field contains Target Device Identifier 

• SAS ADDRESS: field contains the port identifier of the SAS port transmitting this frame. 

• PHY Identifier: field contains the PHY identifier of the PHY transmitting this frame. 

• Break_Reply Capable: set to 1 b to indicate that this port is capable of sending BREAK_REPLY primitive sequence 
in responding of receiving BREAK primitive sequences 

• Requested Inside ZPSDS: set to 0b since this is an "End Device" 

• Inside ZPSDS Persistent: set to 0b since this is an "End Device" 

Table 34 Reason field 


Value 

Address Frame Type Description 

00b 

Power on 

01b 

OPEN: Connection Request 

02b 

Hard Reset (received a Hard Reset during hard reset sequence) 

04b 

Loss of dword synchronization 

07b 

Break timeout timer expired 

08b 

Phy test function stopped 

Others 

RESERVED 
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OPEN Address Frame 


7.6.1.2 

The OPEN address frame format is used for the identification sequence. The OPEN address frame is sent after the 
phy reset sequence completes. The OPEN Address Frame format is defined as follows: 

Table 35 OPEN Address Frame format 


Byte 

Bit 

7 

6 | 5 | 4 

3 2 1 0 

0 

Initiator 

Port=0 

Protocol = 1 

Address Frame Type = 1 

1 

Features = 0 

Connection Rate = 8h or 9h or Ah 

2-3 

Initiator Connection Tag 

4-11 

Destination SAS Address 

12-19 

Source SAS Address 

20 

Source Zone Group 

21 

Pathway Blocked Count 

22-23 

Arbitration Wait Time 

24-27 

More Compatible Features 

28-31 

CRC 


Initiator Port: This bit is set to zero when the Drive is the source port acting as a SAS target. 

Protocol: this field is set to 001b to indicate SSP Protocol. 

Features: this field is set to zero and ignored by the Drive per SAS 1.1. 

Connection Rate: field should be set to 8h (1,5Gbps) or 9h (3Gbps), depending on requested link rate. Rate 
matching is supported by the Drive, therefore if the Link to the drive is 3.0Gbps, and the Connection Rate is 
1.5Gbps, the Drive will insert ALIGNS between DWords, to match the Connection Rate. 

Initiator Connection Tag: The Drive will set this value to the last value received from this Initiator. 

Destination SAS Address: field contains the port identifier of the SAS port to which a connection is being 
requested. 

Source SAS Address: field contains the port identifier on the port that originated this frame (i.e. the drive’s port 
address). 

Source Zone Group: This field is set to zero and ignored by the Drive per SAS 2. 

Pathway Blocked Count: this field indicates the number of times the port has retried this connection request due 
to receiving OPEN REJECT (PATHWAY BLOCKED). The Drive will not increment the PATHWAY BLOCKED 
COUNT value past FFh. 

Arbitration Wait Time: this field indicates how long the port transmitting the OPEN address frame has been 
waiting for a connection request to be accepted. For values from OOOOh to 7FFFh, the Arbitration Wait Time 
timer increments in one microsecond steps. For values from 8000h to FFFFh, the Arbitration Wait Time timer 
increments in one millisecond step. 

More Compatible Features: this field is set to zero and ignored by the Drive per SAS 1.1. 
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7.6.2 Link Layer Error Handling 

This section defines the Link layer error handling of the drive. 


Table 36 Link Layer Error Handling (part 1 of 2) 


Error 

Error Handling Procedure 

IDENTIFY Timeout 

If IDENTIFY is not received before the IDENTIFY timer expires (1ms), firmware is notified 
and the drive transmits a COMINIT to initiate a new link reset. 

BREAK Received 

If BREAK is received while the drive has ACK/NAK balance, BREAK or BREAKREPLY 
is transmitted and a new connection may be opened if the drive still has frames to 
transmit. Firmware is not notified. If BREAK is received while the drive does NOT have 
ACK/NAK balance, BREAK or BREAK REPLY is transmitted and the current command 
is aborted and will return Check Condition status with sense data indicating an ACK/NAK 
timeout. 

NAK and ACK/NAK 
Timeout 

If a NAK is received on a RESPONSE frame, the RESPONSE frame is retransmitted with 
the RETRANSMIT bit set to zero. If an ACK or NAK is not received for a RESPONSE 
frame within 1ms, the RESPONSE frame will be retransmitted with the RETRANSMIT bit 
set to one. The drive will retry sending a RESPONSE frame once. 

Bad Frame CRC 

If a frame fails the CRC check, the frame is NAKed by the drive and discarded. This is a 
link layer function. The command associated with a NAKed DATA or XFER RDY frame is 
aborted with check condition status and sense data corresponding to 

DATA PHASE ERROR is returned. COMMAND frames that fail the CRC check are 
NAKed and discarded. 

OPENREJECT 

OPEN REJECT - Retry able Variations 

OPEN REJECT(RETRY) - Will be retried indefinitely by the drive. This case is 
considered to be occur when the initiator is temporarily not available to accept 
connections (for example when it is not able to extend R-Rdy credit at this time due to 
lack of buffers...), so the initiator will ask us to keep "RETRY"-ing, until it becomes 
available at a later time. Thus, we don't consider this an error condition, but part of 
normal behavior for the initiator. 

OPEN_REJECT(RATE_NOT_SUPPORTED) - If this occurs, it must mean that a link 
between the drive and initiator renegotiated to a lower link rate after the command was 
received. In this case, we retry in a new connection at 1.5Gbps. If this error is received 
for a 1.5Gbps connection, the command is internally aborted. 

OPEN REJECT-(PATHWAY BLOCKED) 

OPEN REJECT (BAD DESTINATION), OPEN REJECT (WRONG DESTINATION), 
OPEN REJECT (PROTOCOL_NOT_SUPPORTED) - If these OPEN_REJECTs are 
received, we internally abort the command. 

Credit Timeout 

If credit is not received before the credit timer expires, DONE(CREDIT_TIMEOUT) is 
sent to the Initiator. 

DONE Timeout 

If credit is extended and the DONE timer expires, BREAK is sent by hardware to tear 
down the connection. 

CREDITBLOCKED 

If CREDIT BLOCKED is received and the drive has frames to send in the current 
connection, DONE(CREDIT TIMEOUT) is returned. Otherwise, DONE(NORMAL) is 
returned. 
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Table 37 Link Layer Error Handling (part 2 of 2) 


Error 

Error Handling Procedure 

OPEN Frame Checking 

Reserved fields in the OPEN frame are not checked. 

The Dest Address field is checked, and if it doesn’t match OPEN REJECT 
(WRONG_DESTINATION) is returned. 

The Protocol field is checked and if it isn’t set to SSP OPEN REJECT 
(PROTOCOLNOTSUPPORTED) is returned. 

If the Link Rate exceeds the physical link rate on that port, OPEN REJECT 
(LINK RATE NOT SUPPORTED) is returned. 

The Initiator bit is not checked. 

OPEN Response Timeout 

If AIP or OPEN ACCEPT is not received before the OPEN Response timer expires, 
the hardware transmits BREAK. 

CLOSE Timeout 

If CLOSE is not received before the CLOSE timer expires, the hardware transmits 
BREAK. 

Phy Not Ready 

If Link Reset occurs outside of a connection, commands can execute normally 
across the link reset. If a link reset occurs inside of a connection, the behavior is 
similar to BREAK in that it is treated as an abruptly closed connection. In cases 
where the command cannot be continued normally (e.g. a frame is corrupted by 

OOB signals, or we do not have ACK/NAK balance), the command is terminated 
with CHECK CONDITION status with sense data corresponding to ACK/NAK 
TIMEOUT. 
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7.7 Transport Layer 

The Transport layer defines frame formats. The Transport layer is the interface between the application layer and 
port layer. It is responsible for constructing and parsing frame contents. For SSP, the transport layer only receives 
frames from the port layer that are going to be ACKed by the link layer. This section describes Transport Layer 
behaviors of the Drive. For a complete description of SAS Transport Layer, please see the ANSI specification, SAS 
1.1. 


The transport layer defines the frame format as follows. 
Table 38 SAS Frame Format 


Byte 

Bit 

7 6 5 4 3 2 1 0 

0 

Frame Type 

1-3 

Hashed Destination Address 

4 

Reserved 

5-7 

Hashed Source Address 

8-9 

Reserved 

10 

Reserved TLR Control = 00b Retry Data 

Frames =0b 

Retransmit Rsvd 

11 

Reserved 

# of fill bytes 

12-15 

Reserved 

16-17 

Tag 

18-19 

Target Port Transfer Tag 

20-23 

Data Offset 

24-m 

Information Unit 


Fill Bytes (if Needed) 

(n-3)-n 

CRC 


• FRAME TYPE field, which defines the format of the INFORMATION UNIT field as follows: 
Table 39 FRAME TYPE field 


Code 

Name of Frame 

Information Unit 

Originator 

IU Size (bytes) 

01 h 

DATA 

Data 

Initiator or Target 

1-1024 

05h 

XFERRDY 

Data Transfer Ready 

Target 

12 

06h 

COMMAND 

Command 

Initiator 

28-284 

07h 

RESPONSE 

Response 

Target 

24-1024 

16h 

TASK 

Task Management Function 

Initiator 

28 

fO-ffh 

vendor specific 

all others 

reserved 


• The HASHED DESTINATION SAS ADDRESS field contains the hashed value of the destination SAS address. 

• The HASHED SOURCE SAS ADDRESS field contains the hashed value of the source SAS address. 

• The TLR CONTROL field is not supported. 

• The RETRY DATA FRAMES is not supported. 

• The CHANGING DATA POINTER is not supported. 


HGST Hard Disk Drive OEM Specification 
62 






The NUMBER OF FILL BYTES field indicates the number of fill bytes between the INFORMATION UNIT field 
and the CRC field. The RETRANSMIT bit is set to one for RESPONSE frames when attempting to retransmit 
this frame due to receiving an error during the initial transmission. It shall be set to zero for all other frame types. 
The NUMBER OF FILL BYTES field shall be set to zero for all frame types except DATA frames. 

The TAG field contains a value that allows the SSP port to establish a context for commands and task 
management functions. 

The TARGET PORT TRANSFER TAG field is set and used by the drive. The initiator should echo this field in 
outbound data IU. 

The INFORMATION UNIT field contains the information unit, the format of which is defined by the FRAME TYPE 
field. 

Fill bytes shall be included after the INFORMATION UNIT field so the CRC field is aligned on a four byte 
boundary. 
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7.7.1 Command Information Unit 

The COMMAND frame is sent by an SSP initiator port to request that a command be processed by the drive. 
Table 40 COMMAND Information Unit 


Byte 

Bit 

7 1 6 | 5 | 4 | 3 | 2 | 1 0 

0-7 

Logical Unit Number 

8 

Reserved 

9 

Disable first Reserved Task Attribute 

burst=0 

10 

Reserved 

11 

Additional CDB Length (in Dwords) Rsvd 

12-27 

CDB 

28-n 

Additional CDB Bytes 


• The LOGICAL UNIT NUMBER field contains the address of the logical unit. The drive only supports a LUN of 0’s 

• A DISABLE FIRST BURST bit is not supported by the drive 

• The TASK ATTRIBUTE field is defined as follows: 

Table 41 TASK ATTRIBUTE field 


Value 

Attribute 

000b 

Simple_Q 

001b 

Head_of_Q 

010b 

Ordered_Q 

100b 

ACA Q (not supported) 

101b 

Reserved 


• The ADDITIONAL CDB LENGTH field contains the length in dwords (four bytes) of the ADDITIONAL CDB field 

• The CDB and ADDITIONAL CDB BYTES fields together contain the CDB. 
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7.7.2 TASK Information Units 


Table 42 TASK Information Unit 


Byte 

Bit 

7 6 5 4 3 21 0 

0-7 

Logical Unit Number 

8-9 

Reserved 

10 

Task Management Function 

11 

Reserved 

12-13 

Tag of Task to be Managed 

14-27 

Reserved 


• The LOGICAL UNIT NUMBER field contains the address of the logical unit. The drive only supports a LUN of 0’s. 

• The TASK MANAGEMENT FUNCTION field is defined as follows: 


Table 43 TASK MANAGEMENT FUNCTION field 


Value 

Function 

01 h 

ABORT TASK: The Drive shall perform the ABORT TASK associated with the value of the TAG OF TASK 
TO BE MANAGED field 

02h 

ABORT TASK SET: The Drive shall perform the ABORT TASK SET by aborting all outstanding tasks for 
the Initiator that sent the TMF. 

04h 

CLEAR TASK SET: This TMF causes the Drive to abort all tasks in the task set. The action is equivalent 
to receiving a series of Abort Task requests from all Initiators. 

A unit attention condition shall be generated for all other Initiators with tasks in the task set. The Additional 
Sense Code shall be Commands cleared by another Initiator. 

08h 

LUN RESET: The LUN RESET causes the Target to execute a hard reset. This means: 

1. Abort all tasks for all Initiators on either both ports. 

2. Release any device reservation on either port. 

Set a Unit Attention condition for all Initiators. 

40h 

CLEAR ACA (not supported) 

80h 

QUERY TASK: The drive shall return a response of FUNCTION SUCCEEDED if the specified task exists, 
or FUNCTION COMPLETE if the specified task does not exist. 

81 h 

QUERY TASK SET: The drive shall return a response of FUNCTION SUCCEEDED if there is any task 
exist, or FUNCTION COMPLETE if there is no task exist. 

82h 

QUERY ASYNCHRONOUS EVENT (formerly QUERY UNIT ATTENTION): The drive shall return a 
response of FUNCTION SUCCEEDED if there is a unit attention or a deferred error pending, or 
FUNCTION COMPLETE if there is no unit attention or no deferred error pending. 

others 

RESERVED: The Drive will return a RESPONSE frame with the DATAPRES field set to 
RESPONSE DATA and its RESPONSE CODE field set to TASK MANAGEMENT FUNCTION NOT 
SUPPORTED. 


If TMF is set to ABORT TASK or QUERY TASK, the TAG OF TASK TO BE MANAGED field specifies the TAG 
value from the COMMAND frame that contained the task to be aborted or checked. For all other TMF’s, this field 
is ignored. 

If TMF is set to QUERY ASYNCHRONOUS EVENT, the Additional Response Information argument is set to 
OOOOOOh for the response of FUNCTION COMPLETE. If the response is FUNCTION SUCCEED, the Additional 
Response Information argument is set as defined in Table 44. 
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Table 44 Additional Response Information argument for Query Async Event 


Byte 

Bit 

7 | 6 

5 4 

3 | 2 | 1 | 0 

0 

RESERVED 

UADE DEPTH 

SENSE KEY 

1 

ADDITIONAL SENSE CODE 

2 

ADDITIONAL SENSE CODE QUALIFIER 


The UADE DEPTH is the number of pending unit attention conditions or deferred errors. It is defined as in Table 45 

The SENSE KEY field is the value of the SENSE KEY field in the highest-priority pending unit attention condition or 
deferred error. 

The ADDITIONAL SENSE CODE field is the value of the ADDITIONAL SENSE CODE field in the highest-priority 
pending unit attention condition or deferred error. 

The ADDITIONAL SENSE CODE QUALIFIER field is the value of the ADDITIONAL SENSE CODE QUALIFIER field 
in the highest-priority pending unit attention condition or deferred error 


Table 45 UADE DEPTH field 


Code 

Description 

00b 

The combined number of unit attention conditions and deferred errors is unknown 

01b 

The combined number of unit attention conditions and deferred errors is one 

10b 

The combined number of unit attention conditions and deferred errors is greater than one 

11b 

Reserved 


7.7.3 XFER_RDY Information Units 

The XFER_RDY frame is sent by the Drive to request write data (i.e. out bound data) from the initiator. 
Table 46 XFER_RDY Information Unit 


Byte 

Bit 

7 6 5 4 3 21 0 

0-3 

REQUESTED OFFSET 

4-7 

WRITE DATA LENGTH 

8-11 

RESERVED 


• The REQUESTED OFFSET field contains the buffer offset of the segment of write data the Initiator may transmit 
to the Drive (using DATA frames). The requested offset shall be a multiple of four. 

• The WRITE DATA LENGTH field contains the number of bytes of write data the Initiator may transmit to the Drive 
(using DATA frames) from the requested offset. 

7.7.4 DATA Information Units 

The DATA frame is sent by the Drive to the Initiator (in bound data) or by the Initiator to the Drive (out bound data). 
Table 47 Data Information Unit 


Byte 

Bit 

7 6 5 4 3 21 0 

0-(n-1) 

DATA 
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7.7.5 RESPONSE Information Units 

The RESPONSE frame is sent by the Drive to the Initiator (in bound data) or by the Initiator to the Drive (out bound 
data). 

Table 48 Response Information Unit 


Byte 

Bit 

7 1 6 | 5 | 4 | 3 | 2 | 1 | 0 

0-7 

RESERVED 

8-9 

MSB 

RETRY DELAY TIMER 

LSB 

10 

RESERVED Data Pres 

11 

STATUS 

12-15 

Reserved 

16-19 

SENSE DATA LENGTH (n bytes) 

20-23 

RESPONSE DATA LENGTH (m bytes) 

24 - (24+m) 

RESPONSE DATA 

(24+m)-(23+m+n) 

SENSE DATA 


The RETRY DELAY TIMER field contains the retry delay timer code which is defined as follows: 
Table 49 RETRY DELAY TIMER field 


Status Code 

Retry Delay 

Timer Code 

Description 

BUSY 

OOOOh 

Same as normal busy 

OOOlh-FFEFh 

The number of 100 milliseconds increments which Initiator should wait 
before sending another command to Drive 

FFFOh-FFFDh 

RESERVED 

FFEFh 

Initiator should stop sending commands to Drive 

FFFFh 

Drive is not able to accept the command 


OOOOh 

Same as normal busy 

QUEUE FULL 

OOOlh-FFEFh 

Initiator should wait before sending another command to the Drive 
until: 

a) At least the number of 100 milliseconds increments indicated in 
the RETRY DELAY TIMER CODE field have elapse; or 

b) A command addressed to the Drive completes. 

FFFOh-FFFFh 

RESERVED 

GOOD 

OOOOh-FFFFh 

RESERVED 

CHECK CONDITION 

OOOOh-FFFFh 

RESERVED 

CONDITION MET 

OOOOh-FFFFh 

RESERVED 

RESERVATION 

CONFLICT 

OOOOh-FFFFh 

RESERVED 

ACA ACTIVE 

OOOOh-FFFFh 

RESERVED 

TASK ABORT 

OOOOh-FFFFh 

RESERVED 


• The DATAPRES field, which indicates the format and content of the STATUS field, SENSE DATA LENGTH field, 
RESPONSE DATA LENGTH field, RESPONSE DATA field, and SENSE DATA field. 
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Table 50 DATAPRES field 


Value 

DATAPRES Description 

00b 

NO DATA: no data present 

01b 

RESPONSE DATA: response data present 

10b 

SENSE_DATA: sense data present 

11b 

RESERVED 


Table 51 RESPONSE CODE 


Byte 

Bit 

7 6 5 4 3 

2 1 

10 

0-2 

RESERVED 

3 

RESPONSE CODE 


• RESPONSE CODES are defined as follows: 
Table 52 RESPONSE DATA 


Value 

RESPONSE Code Description 

00b 

Task Management Function complete 

02b 

Invalid Frame 

04b 

Task Management Function not supported 

05b 

Task Management Function failed 

08b 

Task Management Function succeeded 

09b 

Invalid LUN 

others 

RESERVED 
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7.7.6 Sequences of SSP Information Units 

SSP Information Units are used in conjunction with one another to execute SCSI commands. This section provides 
a brief overview of SAS SSP Information Unit sequences that would be required to complete a SCSI command. 


Initiator Target 

Command IU 


Data IU (s) 

Respo 

nse IU 


Read Type Command 
IU Sequence ' 


Initiator Target 

Command IU 


Write Type Command 
' IU Sequence 1 


Figure 12 SSP Information Unit Sequences 
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7.7.7 Transport Layer Error Handling 

This section defines the Transport layer error handling by the drive. 


Table 53 Transport Layer Error Handling 


Error 

Error Handling Procedure 

SSP Header Field Checking 

Reserved fields in SSP frames are not checked. 

Data Offset Error 

If a DATA frame with an invalid Data Offset is received, the command 
associated with the DATA frame is aborted with Check Condition status and 
sense data corresponding to a DATA OFFSET ERROR is returned 

I T NEXUS Loss Timeout 

If a connection cannot be established to an initiator before the l_T NEXUS 
LOSS timer expires (Mode Page 0x19), all commands from the initiator are 
internally aborted. The first new command received from the affected Initiator 
results in a CHECK CONDITION with sense data corresponding to 1 T 
NEXUS LOSS OCCURRED. 

Initiator Response Timeout 

If DATA frames corresponding to an outstanding XFERRDY frame are not 
received before the Initiator Response timer expires (Mode Page 0x19), the 
command is aborted with CHECK CONDITION status and sense data 
corresponding to INITIATOR RESPONSE TIMEOUT is returned for the 
affected command. 

Data Overflow 

If more data is received than requested via an XFER_RDY frame, the 
affected command is aborted with CHECK CONDITION status with sense 
data corresponding to TOO MUCH WRITE DATA is returned. 

Invalid Target Port Transfer Tag 

If a DATA frame is received and the TPTT is not set to the value used in the 
corresponding XFER RDY frame, the frame is discarded. If a COMMAND or 
TASK frame is received with the TPTT set to a value other than OxFFFF, a 
RESPONSE frame with RESPONSE DATA set to INVALID FRAME is 
returned. 

Invalid Frame Length 

If a DATA frame is received with zero bytes of payload data, the frame is 
discarded. This is not considered an error. If a COMMAND/TASK frame that 
is too short is received, RESPONSE data corresponding to INVALID FRAME 
is returned. The additional CDB length field of a COMMAND frame is not 
checked for correctness. If a DATA frame is received with a payload greater 
than 1024 bytes, the frame is discarded and the command is aborted with 
CHECK CONDITION status and sense data corresponding to 
DATA PHASE ERROR is returned. 
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8 SCSI Command Set 

Summaries of the SCSI commands supported by the drive are listed below. O = optional, M = mandatory, X = 
mandatory as a ZBC device 


Table 54 SCSI Commands Supported (part 1 of 2) 


Type 

Code 

Description 

M 

04h 

FORMAT UNIT (04) 

M 

12h 

INQUIRY (12) 

0 

4Ch 

LOG SELECT (4C) 

0 

4Dh 

LOG SENSE (4D) 

0 

15h 

MODE SELECT (15) 

0 

55h 

MODE SELECT (55) 

0 

1 Ah 

MODE SENSE (1A) 

0 

5Ah 

MODE SENSE (5A) 

0 

5Eh 

PERSISTENT RESERVE IN (5E), 

0 

5Fh 

PERSISTENT RESERVE OUT (5F) 

0 

34h 

PRE-FETCH (34) 

0 

90h 

PRE-FETCH (90) 

M 

08h 

READ (6) - (08) 

M 

28h 

READ (10) - (28) 

0 

A8h 

READ (12) - (A8) 

0 

88h 

READ (16)-(88) 

0 

7Fh/09h 

READ (32) - (7F/09) 

0 

3Ch 

READ BUFFER (3C) 

M 

25h 

READ CAPACITY (10)-(25) 

0 

9Eh/10h 

READ CAPACITY (16) (9E/10) 

0 

37h 

READ DEFECT DATA (37) 

0 

B7h 

READ DEFECT DATA (B7) 

0 

3Eh 

READ LONG (3E),page 207 

0 

9Eh 

READ LONG (9E),page 208 

0 (Not supported) 

07h 

REASSIGN BLOCKS (07) 

0 

ICh 

RECEIVE DIAGNOSTICS RESULTS (1C) 

M 

17h 

RELEASE (17) 

0 

57h 

RELEASE (57) 

0 

A3h/05h 

REPORT DEVICE IDENTIFIER (A3/05) 

0 

AOh 

REPORT LUNS (A0) 

0 

A3h/0Ch 

REPORT SUPPORTED OPERATION CODES (A3/0C) 

0 

A3h/0Dh 

REPORT SUPPORTED TASK MANAGEMENT FUNCTIONS (A3/0D) 

M 

03h 

REQUEST SENSE (03) 

M 

16h 

RESERVE (16) 

0 

56h 

RESERVE (56) 

0 

01 h 

REZERO UNIT (01) 

0 

48h 

SANITIZE 

M 

1 Dh 

SEND DIAGNOSTIC (ID) 

0 

A4h/06h 

SET DEVICE IDENTIFIER (A4/06) 
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Table 55 SCSI Commands Supported (part 2 of 2) 


Type 

Code 

Description 

0 

1 Bh 

START STOP UNIT (IB) 

0 

35h 

SYNCHRONIZE CACHE (10) - (35) 

0 

91 h 

SYNCHRONIZE CACHE (16) - (91) 

M 

OOh 

TEST UNIT READY (00) 

0 

2Fh 

VERIFY (10) - (2F) 

M 

OOh 

TEST UNIT READY (00) 

0 

2Fh 

VERIFY (10) - (2F) 

0 

AFh 

VERIFY (12)-(AF) 

0 

AFh 

VERIFY (16) - (8F) 

0 

7Fh/0Ah 

VERIFY (32) - (7F/0A) 

M 

OAh 

WRITE (6) - (0A) 

M 

2Ah 

WRITE (10) -(2A) 

0 

AAh 

WRITE (12) -(AA) 

0 

8Ah 

WRITE (16) - (8A) 

0 

7Fh/0Bh 

WRITE (32) - (7F/0B) 

0 (Not supported) 

2Eh 

WRITE AND VERIFY (10) - (2E) 

0 (Not supported) 

AEh 

WRITE AND VERIFY (12) - (AE) 

0 (Not supported) 

8Eh 

WRITE AND VERIFY (16) - (8E) 

0 (Not supported) 

7Fh/0Ch 

WRITE AND VERIFY (32) - (7F/0C) 

0 

3Bh 

WRITE BUFFER (3B) 

0 (Not supported) 

3Fh 

WRITE LONG (10) (3F) 

0 (Not supported) 

9Fh 

WRITE LONG (16) (9F) 

0 

41 h 

WRITE SAME (10)-(41) 

0 

93h 

WRITE SAME (16) - (93) 

0 

7Fh/0Dh 

WRITE SAME (32) - (7F/0D) 

X 

94h 

ZBC CLOSE ZONE 

X 

94h 

ZBC FINISH ZONE 

X 

94h 

ZBC OPEN ZONE 

X 

95h 

ZBC REPORT ZONES 

X 

95h 

ZBC RESET WRITE POINTER 
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8.1 SCSI Control Byte 

The Control Byte is the last byte of every CDB. The format of this byte is shown below. 
Table 56 SCSI Control Byte 


Bit 

7 6 

5 4 3 2 1 0 

VU = 0 

Reserved = 0 


VU = VU stands for Vendor Unique. 


Note: * - The drive ignores the link bit and flag bit in the CDB. 


8.2 Abbreviations 


These abbreviations are used throughout the following sections: 
Table 57 Abbereviations 


LUN 

Logical Unit Number. An encoded three bit identifier for the logical unit. 

VU 

Vendor Unique bits 

LBA 

Logical Block Address 

RSVD 

Reserved 

MSB 

Most Significant Byte 

LSB 

Least Significant Byte 


8.3 Byte ordering conventions 

In this specification, where it is not explicitly stated, all multi-byte values are stored with the most significant byte first. 
For example, in a 4 byte field, byte 0 will contain the MSB and byte 3 the LSB. 
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8.4 FORMAT UNIT (04) 


Table 58 FORMAT UNIT 


Byte 

Bit 

7 6 

5 

4 

3 

1 2 1 1 1 0 1 

0 

Command Code = 04h 

1 

FMTPINFO 

LONG 

LIST=0 

FMTDATA 

CMPLIST 

Defect List Format 

2 



VU 

= 0 


3-4 

Obsolete = 0 

5 

VU = 0 


Reserved = 0 

FLAG LINK 


• FMTPINFO (Format Protection Information) in combination with the Protection Field Usage field in the 
Parameter List Header specifies whether or not the drive enables or disables the use of protection information 
(see table defined in the Parameter List Header section). 

• FmtData set to one specifies that a Data Out phase follows the Command phase. The Data Out phase consists 
of a Parameter List header, optionally followed by an Initialization Pattern Descriptor, optionally followed by a 
Defect List. If FmtData=0, the following defaults are assumed: DPRY=0, DCFtT=1, STPF=1, IP=0, DSP=0, 
lmmed=0. 

• CmpLst 

• Set to one specifies that the Grown Defect List (GList) existing prior to the issuance of the Format Unit 
command be discarded. If provided, the DList then becomes the GList. Following these operations, the Drive 
will be formatted with the PList and GList. 

• Set to zero specifies that the GList existing prior to the issuance of the Format Unit command is retained. If 
provided, the DList is combined with the GList to become the new GList. Following these operations, the Drive 
will be formatted with the PList and GList. 

Note: The drive manages two internal defect lists and one external. The Plist is created at time of manufacture. 
The Glist is built after manufacture by the Initiators’ use of the REASSIGN BLOCK command and the 
Automatic Reallocate functions. The Dlist is an external list. It is supplied by the Initiator in the Data Out 
phase of the FORMAT UNIT command. 

• Defect List Format specifies the format of the defect descriptor transferred to the Target when FmtData bit is 
set to one. The Target supports the following three defect descriptor formats for the FORMAT UNIT command: 


Table 59 Defect descriptor format 


Format 

Description 

000b 

Block format 

100b 

Bytes From Index format 

101b 

Physical Sector format 


If the FmtData bit is set to zero, this field must also be zero. Otherwise the command will complete with a CHECK 
CONDITION with a sense key of Illegal Request and an additional sense code of Invalid Field in CDB. 

Note: It is recommended that the MODE SELECT command be issued prior to the FORMAT UNIT command to 
specify parameters that affect the formatting process. 

The Block Length parameter of the Mode Select Parameter List’s Block Descriptor is used during formatting and is 
saved following a successful format operation. If a MODE SELECT command has not been issued since the last 
reset or start-up (bring-up) sequence, then the Block Length from the previous format operation is used. 

Subsequent to receiving a FORMAT UNIT command, the Target responds to commands as follows: 

- All commands except REQUEST SENSE and INQUIRY return Check Condition status, while the format 
operation is an active I/O process. 

- When tagged queuing is enabled (DQue = 0), all commands except REQUEST SENSE and INQUIRY return 
Queue Full status, while the FORMAT UNIT command is a queued I/O process. 
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- When tagged queuing is disabled (DQue = 1), all commands except REQUEST SENSE and INQUIRY return 
Busy status, while the FORMAT UNIT command is a queued I/O process 

- If a REQUEST SENSE command is received while a format operation is an active I/O process, the Target returns 
Good status. The sense key is set to Not ready and the additional sense code and qualifier is set to Format In 
Progress. 

- If an INQUIRY command is received while a format operation is an active I/O process, the Target returns Good 
status and Inquiry data as requested. 

The format operation must complete successfully for the Drive to be usable. If the command is interrupted by a reset, 
power down, or an unrecoverable error, the Drive enters a degraded mode of operation in which reading and writing 
are prohibited. To exit the degraded mode, another FORMAT UNIT command must be sent by the Initiator and 
completed successfully by the Target. 

The FORMAT UNIT command sets the Unit Attention Condition for all Initiators except the one that issued the 
FORMAT UNIT command. 

Write Poriter at the designated band (in the current partition) will be reset by Format Unit command. 

• This does not change active band 

• Target zone must be sequential write required zone 

• Command reception is recorded in drive internal event log 
Note: About resetting the write pointer, please refer 4.16. 

The Format Unit command only initializes the Indirection Table to initialize all user data sectors in sequential write 
required zones and also initializes all user data sectors in conventional write zone with media write if fast format 
Enable (FFME) bit in Mode Page 0 is disabled., after merging reassigned sector location into the defect information 
of the device and clearing the reassign information. Both new reassign information and new defect information are 
available right after command completion of this command. Previous information of reassign and defect are erased 
from the device by executing this command. 

8.4.1 Parameter List Header 

Following is the format of the Parameter List Fleader sent during the data out phase when FmtData is set to one. 


Table 60 Format of the Short Parameter List Header 


Byte 

Bit 

7 6 5 4 3 

21 0 

0 

Reserved = 0 

Protection Field Usage 

1 

FOV DPRY DCRT STPF =1 IP 

Obsolete Immed Vendor-specific 

2-3 

(MSB) 

Defect 

List Length(LSB) 

4-n 

Initialization Pattern Descriptor 

(n+1)-m 

Defect Descriptor 
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Table 61 Format of the Long Parameter List Header 


Byte 

Bit 

7 6 5 4 3 

2 1 1 1 0 

0 

Reserved = 0 

Protection Field Usage 

1 

FOV DPRY DCRT STPF =1 IP 

Obsolete Immed Vendor-specific 

2 

Reserved 

3 

PJJNFORMATION = 0 PROTECTION INTERVAL EXPONENT = 0 

4...7 

(MSB) 

DEFECT LIST LENGTH 

(LSB) 

8-n 

Initialization Pattern Descriptor 

(n+1)-m 

Defect Descriptor 


• Protection Field Usage: in combination with the format protection information (FMTPINFO) field in the CDB 
specifies whether or not the drive enables or disables the use of protection information: 

Table 62 Format of the Long Parameter List Header 


FMTPINFO 

Protection 

Field Usage 

Description 

OOh 

OOOh 

The drive will be formatted to type 0 protection 

01 h 

xxx h 

Check Condition status will be returned with the sense key set to Illegal Request 
and the additional sense code set to Invalid Field in the CDB. 

lOh 

OOOh 

The drive will be formatted to type 1 protection 

11 h 

OOOh 

The drive will be formatted to type 2 protection 

11 h 

001 h 

Type 3 protection is not supported - Check Condition status will be returned with 
the sense key set to Illegal Request and the additional sense code set to Invalid 
Field in the Parameter List 


All other combinations of FMTPINFO and Protection Field Usage will result in Check Condition status to be returned 
with the sense key set to Illegal Request and the additional sense code set to Invalid Field in the Parameter List. 


Type 0 protection specifies that the drive shall disable the use of protection information and format to the block size 
specified. Following a successful format, the PROT_EN bit in the READ CAPACITY (16) parameter data will indicate 
that protection information is disabled. 

Type 1 and type 2 protection specifies that the drive shall enable the use of protection information and format to the 
block size specified + 8 (e.g., if the block length is 512, then the formatted block length is 520). See format of data 
below. When protection information is written during a FORMAT UNIT command, protection information shall be 
written with a default value of all OxFF's. Following a successful format, the PROT EN bit in the READ CAPACITY 
(16) parameter data will indicate that protection information is enabled and the P_TYPE field in the READ CAPACITY 
(16) parameter data will indicate the protection type. 
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Table 63 Data Format with Protection field 


Byte 

Bit 

7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 

0... n 

User Data 

n... n+1 

Logical Block Guard 

n+2... n+3 

Logical Block Application Tag 

n+4... n+7 

Logical Block Reference Tag 


The Logical Block Guard field contains a CRC that covers the preceding user data. This field is 
generated/checked per the SBC standard. 

The Logical Block Application Tag field may be modified by the initiator if the ATO bit is set to zero in mode 
page OxOA. If the ATO bit is set to one, then the initiator shall not modify the Logical Block Application Tag field. 
This field is generated/checked per the SBC standard. 

The Logical Block Reference Tag field is generated/checked depending on protection types. With Type 1 
protection, the Logical Block Reference Tag in the first logical block of the data transfer shall contain the least 
significant four bytes of the LBA contained in the Logical Block Address field of the command. Subsequent blocks 
shall contain the previous logical block reference tag plus one. With Type 2 protection, the Logical Block 
Reference Tag in the first logical block of the data transfer shall contain the value in the Expected Initial Logical 
Block Reference Tag field of the command. Subsequent blocks shall contain the previous logical block reference 
tag plus one. 

FOV (Format Options Valid) bit set to zero indicates that the Target should use its default settings for the DPRY 
(0), DCRT (1), STPF (1), IP (0), and DSP (1) bits. These bits must all be set to zero in the Parameter List Header 
when FOV=0, or the command will be terminated with Check Condition status, sense key of Illegal Request, and 
additional sense code of Invalid Field in Parameter List. FOV=1 indicates that the values set in DPRY, DCRT, 
STPF, IP, and DSP will be defined as specified below. 

DPRY (Disable Primary) bit set to zero indicates that the Target does not use portions of the medium identified 
as defective in the primary defect Plist for Initiator addressable logical blocks. If the Target cannot locate the Plist 
or it cannot determine whether a Plist exists, the Target terminates the FORMAT UNIT command as described 
for STPF=1. A DPRY bit set to one indicates that the Target does not use the Plist to identify defective areas of 
the medium. The Plist is not deleted. DPRY must be set to 0 when DCRT is set to 0. 

DCRT (Disable Certification) bit set to zero indicates that the Target performs a medium certification operation 
and generates a Certification List (Clist), and adds the Clist to the Glist. DPRY must be set to 0 when DCRT is 
set to 0. A DCRT bit of one indicates that the Target does not generate a Clist or perform a certification process. 
Note: Since the DCRT bit is part of the Data Out phase that follows the FORMAT command, the FCERT bit in 
Mode Page 0 is provided to control certification when the FORMAT command is issued with no Data Out 
phase. If a FORMAT command is issued with a Data Out phase then FCERT is ignored. 

STPF (Stop Format) bit must be set to one. If one or both of the following conditions occurs, the Target terminates 
the FORMAT UNIT command with Check Condition status. The sense key is set to Medium Error and the 
additional sense code is set to Defect List Not Found if the first condition occurred or to Defect List Error if the 
second condition occurred. 

• The Target cannot locate a required Dlist nor determine that the list exists. 

• The Target encounters an unrecoverable error while accessing a required Dlist. 

IP (Initialization Pattern) bit set to zero specifies that an initialization pattern descriptor is not included and all 
customer data will be initialized to zeroes. An IP bit of one specifies that an Initialization Pattern Descriptor is 
included in the FORMAT UNIT parameter list following the parameter list header. 
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8.4.2 Initialization Pattern 

Table 64 Initialization Pattern Descriptor 


Byte 

Bit 

7 | 6 

5 

4 | 3 | 2 | 1 | 0 

0 

IP Modifier = 0 

SI 

Reserved = 0 

1 

Initialization Pattern Type = 0 or 1 

2-3 

Initialization Pattern Length (n-3) 

4 

Initialization Pattern 

Initialization Pattern 


n 


IP Modifier must be set to 0, indicating that the drive will not modify the initialization pattern. 

SI (Security Initialize) bit set to one specifies that all customer data sectors, including those that have been 
previously reassigned, will be initialized. SI set to zero specifies that only the current customer accessible sectors 
will be formatted. 

Initialization Pattern Type 

- Type of 0 will use a default initialization pattern. 

- Type of 1 specifies that the Initialization Pattern specified shall be repeated as required to fill each logical block. 
Initialization Pattern Length specifies the number of bytes that follow in the Initialization Pattern field, and must 
be less than or equal to the current block size, and non-zero. 

- If Initialization Pattern Type is 0 and the Initialization Pattern Length is not set to 0, Check Condition status will 
be returned, with the sense key set to Illegal Request and the additional sense code set to Invalid Field in 
Parameter List 

- If Initialization Pattern Type is 1 and the Initialization Pattern Length is set to 0, Check Condition status will be 
returned, with the sense key set to Illegal Request and the additional sense code set to Invalid Field in 
Parameter List. 

DSP (Disable Saving Parameters) bit when zero indicates the target is to save all the current MODE SELECT 
saveable parameters during the format operation. When the bit is one, the target is not to save the current MODE 
SELECT saveable parameters. 

Immed (Immediate) bit set to zero requests that status be returned at the end of the format operation. An 
immediate bit set to one requests that status be returned immediately following CDB validation and transfer of 
data in the Data Out phase. If the format operation, with the immediate bit set to one, terminates in error, 
DEFERRED ERROR SENSE data is generated. 

Defect List Length field specifies the total length in bytes of the defect descriptors that follow (not including the 
Initialization Pattern Descriptor, if any). Up to 1024 defect descriptors are allowed. The Defect List Length must 
be equal to four times the number of defect descriptors for BLOCK format, or eight times the number of defect 
descriptors for BYTES FROM INDEX and PHYSICAL SECTOR formats. Otherwise the command is terminated 
with Check Condition status with the sense key set to Illegal Request and the additional sense code set to Invalid 
Field in Parameter List. 
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8.4.3 Defect Descriptor 

Three defect descriptor formats are supported. Entries are not required to be in ascending order. If an entry does not 
correspond to a valid user addressable media location, the command terminates with Check Condition status with 
the sense key set to Illegal Request and the additional sense code set to Invalid Field in Parameter List. 

8.4.3.1 Block Format - 000b 

Format of the Dlist sent during the data out phase when Dlist Format is Block format (000b) and FmtData is set to 
one. 

Table 65 Defect Descriptor - Block Format (for n + 1 defects) 


Byte 

Bit 

7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 

0-3 

(MSB) 

Defective Logical Block Address 

(LSB) 

4n 

4n+1 

4n+2 

4n+3 

(MSB) 

Defective Logical Block Address n 

(LSB) 


The Block format of the Dlist is the LBA of each defective sector. 

Note: If a Defective LBA entry, when converted to a physical sector, is equal to the physical sector of a Plist entry 
and DPRY = 1, then the entry is not added to the Glist. 
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8.4.3.2 Bytes From Index Format - 100b 

Format of the Dlist sent during the data out phase when Dlist Format is Bytes from Index format (100b) and FmtData 
is set to one. 


Table 66 Defect Descriptor - Bytes from Index Format (for n = 1 defects) 


Byte 

Bit 

7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 

0-2 

(MSB) 

Cylinder Number of Defect 

(LSB) 

3 

Head Number of Defect 

4-7 

(MSB) 

Defect Bytes from Index 

(LSB) 

8n 

8n + 1 

8n + 2 

(MSB) 

Cylinder Number of Defect n 

(LSB) 

8n + 3 

Head Number of Defect n 

8n + 4 

8n + 5 

8n + 6 

8n + 7 

(MSB) 

Defect (n) Bytes from Index 

(LSB) 


Each defect descriptor for the Bytes from Index format specifies that the sector containing this byte be marked 
defective. The defect descriptor is comprised of the cylinder number of the defect, the head number of the defect, 
and the number of the defect byte relative to index. 

Note: If a Byte from Index entry, when converted to a physical sector, is equal to the physical sector of a Plist entry 
and DPRY = 1, then the entry is not added to the Glist. 
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8.4.3.3 Physical Sector Format - 101b 

Format of the Dlist sent during the data out phase when Dlist Format is Physical Sector format (101b) and FmtData 
is set to one. 


Table 67 Defect Descriptor - Physical Sector Format (for n + 1 defects) 


Byte 

Bit 

7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 

0 

1 

2 

(MSB) 

Cylinder Number of Defect 

(LSB) 

3 

Head Number of Defect 

4 

5 

6 

7 

(MSB) 

Defect Sector Number 

(LSB) 

8n 

8n + 1 

8n + 2 

(MSB) 

Cylinder Number of Defect n 

(LSB) 

8n + 3 

Head Number of Defect n 

8n + 4 

8n + 5 

8n + 6 

8n + 7 

(MSB) 

Defect (n) Sector Number 

(LSB) 


Each defect descriptor for the Physical Sector format specifies a defective sector. The defect descriptor is comprised 
of the cylinder number of the defect, the head number of the defect, and the defect’s sector number. 

Note: If a Physical Sector entry, when converted to a physical sector, is equal to the physical sector of a Plist entry 
and DPRY = 1, then the entry is not added to the Glist. 
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8.5 INQUIRY (12) 


Table 68 INQUIRY (12) 


Byte 

Bit 

7 6 

5 4 3 2 

1 

0 

0 

Operation Code = 12h 

1 


Reserved = 0 

CmdDt =0 

EVPD 

2 

Page Code 

3-4 

Allocation Length 

5 

VU = 0 

Reserved = 0 

FLAG 

LINK 


The INQUIRY command requests the parameters of the Target to be sent to the Initiator. 

An EVPD An EVPD bit of one specifies that the target return the vital product data page identified by the Page Code 
field in the CDB the available VPD pages are defined in the addendum provided for each different drive model in the 
section entitled Inquiry Data Format. 

The Page Code specifies which page of vital product data information the drive shall return. 


Table 69 Page Code descriptions 


EVPD 

PAGE 

CODE 

Description 

0 

0 

The Target returns the standard INQUIRY data. 

0 

Non Zero 

The drive returns Check Condition status with the sense key of Illegal Request and the 
additional sense code of Invalid Field in CDB. 

1 

Non Zero 

The drive returns the vital product data of page code requested. 


Allocation Length specifies the number of bytes that the Initiator has allocated for INQUIRY data to be returned. An 
allocation length of zero implies that no data is to be returned. The Target will terminate the DATA IN phase when all 
available INQUIRY data has been transferred or when allocation length bytes have been transferred, whichever is 
less. 

Note: If an INQUIRY command is received from an Initiator with a pending unit attention condition (before the target 
reports Check Condition status), the Target processes the INQUIRY command. The unit attention condition is 
not cleared by this action. 

Note: The INQUIRY command is a Priority command and is not queued. 

Note: The inquiry data is set at the time of manufacture and will not change, with the following exceptions: 

• Product Revision Level (EVPD=0) can be changed when microcode is downloaded with the Write Buffer 
command. 

• The information returned for EVPD=1, Page Code = 3 is not fixed. 

Note: The inquiry data returned when media is not available will not be complete. 

Byte 0 of the returned data on an INQUIRY command is the same no matter which page(s) is (are) returned. This 
description is to be used for all the following page definitions. 

The Peripheral Qualifier field of zero (0) indicates that the peripheral device is currently connected to this logical unit. 
A Peripheral Device Type field of zero (0) indicates that this device is a Direct Access Storage Device (DASD). 
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8.5.1 Inquiry Data 

Fields with a value shown inside quotes (e.g. Value =’xyz’) are character fields. A value not in quotes is a numeric 
value. Character fields are alphanumeric and represented in either ASCII. 

8.5.1.1 Inquiry Data Format - EVPD = 0, Page Code = 0 


Table 70 Inquiry Data- EVPD = 0 


Byte 

Bit 

765 

4 | 3 | 2 | 1 | 0 

0 

Qualifier = 0 

Peripheral Device Type = 0x14 

1 

RMB=0 Reserved=0 

2 

Version = 6 

3 

Obsolete 

Obsolete 

Norm 

ACA=0 

HiSup=1 

Response Data Format = 2 

4 

Additional Length = 159 (9Fh) 

5 

sccs=o 

ACC=0 

TPGS=00b 

3PC=0 Reserved = 0 

Protects 

6 

Obsolete 

EncSer=0 

Port 

MultiP=1 

Obsolete 

RSVD = 0 

7 

Obsolete 

Obsolete 

RSVD=0 

RSVD=0 

Obsolete Obsolete CmdQue= 1 

RSVD = 0 

8-15 

Vendor ID = "HGST " (ASCII) 

16-31 

Product ID (ASCII) 

32-35 

Product Revision Level (ASCII) 

36-43 

Unit Serial Number (ASCII) 

44-95 

Reserved = 0 

96-145 

Copyright Notice (ASCII) 

146-163 

Reserved=0 


Qualifier is set to zero to indicate that the LUN specified is currently supported. Qualifier is set to 011 b when the 
LUN specified is not present 1 

Peripheral Device Type is set to 0x14 to indicate that the device is Ultrastar Archive HalO. 

Removal Media Bit (RMB) is always set to zero to indicate no removal media exists. 

Version indicates the level of the ANSI standard that the product supports. The drive supports ANSI SPC-4. 
NormACA (Normal ACA) field of 0 indicates the drive does not support setting the NACA bit to one in the Control 
Byte of the CDB as defined in the SAM. 

HiSup bit of 1 indicates that the drive uses the hierarchical addressing model to assign LUNs to logical units. 
Response Data Format is set to two to indicate that the INQUIRY Data Format as specified in the ANSI SCSI 
version 2 is supported by the Target. 

Additional Length indicates the number of bytes of INQUIRY information that follows. 

SCCS bit of zero indicates that the device does not contain an embedded storage array controller component. 
ACC bit of zero indicates that no access controls coordinator may be addressed through this logical unit. 

TGPS field of zero indicates that the device does not support asymmetric logical unit access. 

3PC bit of zero indicates that the device does not support third-party copy commands. 

Protect bit of one indicates that the drive supports protection information 

EncSer (Enclosure Services) bit of 0 indicates that the Target does not contain an embedded enclosure services 
component. 

Port bit of 0 indicates that the drive received the Inquiry command on port A, while a Port bit of 1 indicates that 


'If an INVALID LUN is specified, a Check Condition status will be returned for all commands except INQUIRY and REQUEST SENSE. 
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the drive received the Inquiry command on port B. 

MultiP (MultiPort) bit of 1 indicates that the Target has multiple ports and implements multi-port requirements. 
CmdQue is set to one to indicate that the drive supports command queuing. 

Vendor ID is HGST padded with ASCII blanks. 

Product ID is specified 

Product Revision Level indicates the level of microcode. 

Unit Serial Number contains the drive serial number. 
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8.5.1.2 Inquiry Data Format - EVPD = 1 - Page Code = OOh 


Table 71 Inquiry Data - EVPD = 1 (Page Code = OOh) 


Byte 

Bit 

7 6 5 

4 | 3 | 2 | 1 | 0 

0 

Qualifier = 0 

Peripheral Device Type = 0 

1 

Page Code = OOh 

2 

Reserved = 0 

3 

Page Length = OEh 

4 

Supported Page Code - OOh 

5 

Supported Page Code - 03h 

6 

Supported Page Code - 80h 

7 

Supported Page Code - 83h 

8 

Supported Page Code = 86h 

9 

Supported Page Code = 87h 

10 

Supported Page Code = 88h 

11 

Supported Page Code - 8Ah 

12 

Supported Page Code - 90h 

13 

Supported Page Code - 91 h 


• Qualifier is set to zero to indicate that the LUN specified in the Command Block is currently supported. 

• Peripheral Device Type is set to zero to indicate that the device is Direct Access. 

• Page Code is set to 0, and this field contains the same value as in the page code field of the INQUIRY command 
descriptor block. 

• Page length specifies the length of the following page data. 

• Supported Page Code field contains the Page Codes supported by the Target. The list is in ascending order. 
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8.5.1.3 Inquiry Data Format - EVPD = 1, Page Code - 03h 


Table 72 Inquiry Data - EVPD = 1 (Page Code = 03h) 


Byte 

Bit 

7 | 6 | 5 

4 3 2 1 0 

0 

Qualifier = 0 

Peripheral Device Type = 0 

1 

Page Code = 03h 

2 

Reserved = 0 

3 

Page Length = 188 (BCh) 

4 

ASCII Fields Length = OOh 

5-7 

Reserved = 0 

8-23 

Reserved = 0 

24-35 

ASCII uCode Identifier 

36-39 

ASCII Servo P/N 

40-41 

Major Version 

42-43 

Minor Version 

44-47 

User Count 

48-51 

Build Number 

52-83 

Build Date String 

84-91 

Product ID 

92-99 

Interface ID 

100-107 

Code Type 

108-119 

User Name 

120-135 

Machine Name 

136-167 

Directory Name 

168-171 

Operating State 

172-175 

Functional Mode 

176-179 

Degraded Reason 

180-183 

Broken Reason 

184-187 

Code Mode 

188-191 

Flash Code Revision Level 


Qualifier is set to zero to indicate that the LUN specified in the Command Block is currently supported. 
Peripheral Device Type is set to 0x14 to indicate that the device is Ultrastar Archive HalO. 

Page Code is set to the value of the page code field in the CDB. 

Page Length field specifies the length (in bytes) of the vendor unique VPD information (bytes 4 - 163). If the 
allocation length of the CDB is too small to transfer all the data, the Page Length field is not adjusted to reflect 
the truncation. 

ASCII uCode Identifier contains the drive’s microcode identifier. The field is alphanumeric (ASCII), left aligned, 
and the unused bytes are ASCII spaces (20h). 

ASCII Servo P/N contains the part number of the Servo microcode installed on the drive. This field is hex numeric 
ASCII (i.e., the characters will be in the set 0...9, A...F). 

Major Version and Minor Version are version numbers of the code loaded on the drive. 

User Count is the number of times the code has been built since the master build. 

Build Number is the master build version number. 
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• Build Date String is the date the code on the drive was built, in an extended string format. 

• Product ID is the name of the product this code is for. 

• Interface ID is the interface type and serial interface speed (e.g. SAS 6Gbps or FCAL 4Gbps) of the code. 

• Code Type is the intended use of the this code. (e.g. local, released, test) 

• User Name is the username of the person who built this version of the code. 

• Machine Name is the workstation on which this version of the code was built. 

• Directory Name is the last 32 characters of the directory from where this code was built. 

• Operating State is the drive operating state. The least significant bit contains the following: 


Table 73 Operating State 


0 = OMBROKEN 

We have detected a hardware failure. 

1 = OMDEGRADED 

We have a soft failure; i.e., incomplete format. Motor is still spinning. 

2 = OMINACCESSIBL 

Drive is good but motor is stopped. 

3 = OMSTARTING 

Motor is starting. 

4 = OMSPINNING 

Motor is started but reserved area is not loaded yet. 

5 = OMNORMAL 

Drive is spinning and ready to read/write. 

6 = OMPOW ERSAVE 

Drive is ready but has entered power save mode. 

7 = OMSTOPPED 

Drive has come ready but now has been stopped. 

8 = OMNOTIFY 

Drive is good but NOTIFY has not arrived (SAS) 

9 = OMSUSPEND 

Similar to OM_STOPPED, but spin-up is automatic like OM_SLEEP 

10 = OMWAKEUP 

Similar to OM STARTING, but LUN BECOMING READY during spinup is not 
reported 

11 = OMNOTIFYWAKEUP 

Similar to OM NOTIFY, but next transition is to OM_WAKEUP 


• Functional Mode is the drive functional mode. The least significant byte (OxOOOOOOOn) contains the following: 
Table 74 Functional Mode 


0 = OMNORMALMODE 

Not in special or recovery mode. 

1 = OMSPECIALCMD 

Special command mode on. 


• Degraded Reason (UECType) is why the file is in a degraded mode; i.e., how to exit this mode. 

• Broken Reason (UECType) is why the drive believes the hardware is broken. 

• Code Mode is the type of code the drive is running. The least significant bit contains the following: 
Table 75 Code Mode 


0 = OMFLASH 

Drive is running flash code 

1 = OMFLASHOVERLAY 

Drive is running flash overlay code 

2 = OMDISK 

Drive is running code that has been loaded from disk 

3 = OMTRANSIENT 

Drive is running code that has been downloaded but not saved 


• Flash Code Revision Level is the revision level of the code in flash. 
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8.5.1.4 Inquiry Data Format - EVPD = 1, Page Code - 80h 


Table 76 Inquiry Data - EVPD = 1 (Page Code = 80h) 


Byte 

! Bit 1 

7 | 6 | 5 

4 | 3 | 2 | 1 | 0 

0 

Qualifier = 0 

Peripheral Device Type = 0 

1 

Page Code = 80h 

2 

Reserved = 0 

3 

Page Length = 16 (1 Oh) 

4-19 

Serial Number (ASCII) 


• Qualifier is set to zero to indicate that the LUN specified in the Command Block is currently supported. 

• Peripheral Device Type is set to zero to indicate that the device is Direct Access. 

• Page Code is set to the value of the page code field in the CDB. 

• Page Length is set to 16, and this field specifies the length of the following page data. 

• Serial Number gives the drive serial number, right aligned. 
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8.5.1.5 Inquiry Data - EVPD = 1 (Page Code = 83h) 


Table 77 Inquiry Data Format - EVPD = 1, (Page Code - 83h) (part 1 of 2) 


Byte 

Bit 

765 

4 3 2 1 0 

0 

Qualifier = 0 

Peripheral Device Type = 0 

1 

Page Code = 83h 

2 

Reserved = 0 

3 

Page Length = 72 (48h) 

4 

Protocol Identifier = Oh 

Code Set = 1 

5 

PIV=0 RSVD Associations 

Identifier Type = 3 

6 

Reserved = 0 

7 

Identifier Length = 8 

8-15 

(MSB) 

LUN (Worldwide ID) 

(LSB) 

16 

Protocol Identifier = 6h 

Code Set = 1 

17 

PIV=1 RSVD Association = 1 

Identifier Type = 3 

18 

Reserved = 0 

19 

Identifier Length = 8 

20-27 

(MSB) 

Target Port Identifier (World Wide ID) 

(LSB) 

28 

Protocol Identifier = 6h 

Code Set = 1 

29 

PIV=1 RSVD Association = 1 

Identifier Type = 4 

30 

Reserved = 0 

31 

Identifier Length = 4 

32-35 

(MSB) 

Relative Port Identifier 

(LSB) 

36 

Protocol Identifier = 6h 

Code Set = 1 

37 

PIV=1 RSVD Association = 2 

Identifier Type = 3 

38 

Reserved = 0 

39 

Identifier Length = 8 

40-47 

(MSB) 

Target Device Name Identifier (World Wide ID) 

(LSB) 
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Table 78 Inquiry Data Format - EVPD = 1, (Page Code - 83h) (part 2 of 2) 


Byte 

Bit 

7 6 5 4 

3 2 10 

48 

Protocol Identifier = Oh 

Code Set = 3 

49 

PIV=0 RSVD Association=2 

Identifier Type = 8 

50 

Reserved = 0 

51 

Identifier Length =24 (18h) 

52-55 

"naa" (ASCII) 

56-71 

(MSB) 

Target Device Name Identifier (World Wide ID) in ASCII 

(LSB) 

72-75 

Reserved = 0 


Protocol Identifier is valid only when PIV=1.Protocol Identifier = 0 indicates Fibre Channel devices.Protocol 
Identifier = 6 specifies SAS devices 

Code Set specifies the data type for the identifier field. Code Set = 1 indicates binary data, Code Set = 3 indicates 
ASCII. 

PIV (Protocol Identifier Valid) set to zero indicates that the Protocol Identifier field should be ignored. PIV set 
to one indicates that the Protocol Identifier field contains a valid value. 

Association specifies the entity with which the Identifier field is associated: Oh for LUN, 1 h for Target or Relative 
Port, or 2h for Target Device. 

Identifier Type specifies the format and assignment authority for the identifier: 3h indicates NAA format of the 
WWID for LUN, Target Port and Target Device; 4h indicates Relative Port; 8h indicates SCSI name string. 
Identifier fields contain the actual Identifier Descriptor: 

- The LUN, Target Port and Target Device Name Identifiers are defined in the NAA IEE WWID format where: 

- Worldwide ID is a 64-bit unique identification for each drive. The format is:5000CCAh xxxh yyb n where: 

- xxx is the 12-bit block assignment defined for each model and manufacturing site 

- n is the 22-bit drive unique serial number 

- yy is the 2-bit port/node ID select 

- The Relative Port Identifier indicates the port which received the Inquiry command:0000 0001 h for the 
Primary Port, or 0000 0002h for the Secondary Port. 
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8.5.1.6 Inquiry Data Format - EVPD = 1, Page Code - 86h 


Table 79 Inquiry Data Format - EVPD = 1, (Page Code - 86h) 


Byte 

Bit 

7 1 6 

5 

4 

3 

2 

1 

0 

0 

Peripheral Qualifier 

Peripheral Device Type 

1 

Page Code = 86h 

2-3 

(MSB) 


Page Length (003Ch) 


(LSB) 


4 

Activate Microcode 

SPT 

GRDCHK 

APPCHK 

REFCHK 

5 

Reserved 

UASKSUP 

Group_Sup 

Prior_Sup 

HEADSUP 

ORDSUP 

SIMPSUP 

6 

Reserved 

WU_SUP 

CRD_SUP 

NVSUP 

V_SUP 

7 

Reserved 

P.LLSUP 

Reserved 

LUICLR 

8 

Reserved 

R_SUP 

Reserved 

CBCS 

9 

Reserved 

Multi l_T Nexus Microcode Download 

10-11 

(MSB) Extended Self-Test Completion Minutes(LSB) 

12 

POASUP HRASUP 

VSASUP 



Reserved 



13 

Maximum Supported Sense Data Length 

14-63 

Reserved 


Activate Microcode field is set to 01b to indicate that the drive 

1) activates the microcode before completion of the final command in the WRITE BUFFER sequence; and 

2) establishes a unit attention condition for the initiator port associated with every l_T nexus, except the l_T 
nexus on which the WRITE BUFFER command was received, with the additional sense code set to 
MICROCODE HAS BEEN CHANGED. 

SPT (Supported Protection Type) field is set to 001b to indicate that the drive supports type 1 and type 2 
protection. 

GRD_CHK (Guard Check) is set to one to indicate that the drive checks the Logical Block Guard Tag field in 
the protection information, if any. 

APPCHK (Application Tag Check) bit is set to one to indicate that the drive checks the Logical Block 
Application Tag field in the protection information, if any. 

REF_CHK (Reference Tag Check) bit is set to one to indicate that the drive checks the Logical Block Reference 
Tag field in the protection information, if any. 

UASK_SUP (Unit Attention Condition Sense Key Specific Data Supported) bit is set to zero to indicate that 
the drive does not return sense-key specific data for the UNIT ATTENTION sense key. 

GROUP_SUP (Group Supported) bit is set to zero to indicate that the grouping function is not supported. 
PRIOR_SUP (Priority Supported) bit is set to zero to indicate that task priority is not supported. 

HEADSUP (Head of Queue Supported), ORDSUP (Ordered Supported), and SIMPSUP (Simple Supported) 
are set to one to indicate support for Head of Queue, Ordered and Simple task attributes. 

WU_SUP is set to zero as Write Long command is not supported. 

CRD_SUP is set to zero as Write Long command is not supported. 

NV_SUP (Non-volatile Supported) is set to zero to indicate that non-volatile cache features are not supported. 
V_SUP (Volatile Supported) is set to one to indicate support of a volatile cache. 

P_I_I_SUP (Protection Information Interval Supported) bit is set to zero to indicate that the logical unit does 
not support protection information intervals. 

R_SUP (Referrals Supported) bit is set to zero to indicate that the drive does not support referrals. 

POA_SUP (Power On Activation Supported) bit is set to zero to indicate that the drive does not support a 
WRITE BUFFER command with the MODE field set to ODh and the PO_ACT bit set to one. 

HRA_SUP (Hard Reset Activation Supported) bit is set to zero to indicate that the drive does not support a 
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WRITE BUFFER command with the MODE field set to ODh and the HRACT bit set to one. 

• VRA_SUP (Vendor Specific Activation Supported) bit is set to zero to indicate that the drive does not support 
a WRITE BUFFER command with the MODE field set to ODh and the VSE ACT bit set to one. 

• Maximum Supported Sense Data Length field indicates the maximum length in bytes of sense data that the 
drive is capable of returning in the same l_T_L_Q nexus transaction as the status. 

8.5.1.7 Inquiry Data Format - EVPD = 1, Page Code - 87h 


Table 80 Inquiry Data Format - EVPD = 1, (Page Code - 87h) 


Byte 

Bit 

765 

4 3 2 1 0 

0 

Qualifier = 0 

Peripheral Device Type = 0 

1 

Page Code = 87h 

2-3 

Page Length = 0004h 

4 

Reserved=0 Policy Page Code = 3Fh 

5 

Policy Subpage Code = FFh 

6 

MILUS=1 Reserved = 0 Mode PagePolicy = 0 

7 

Reserved = 0 


• Policy Page Code set to 3Fh and Policy Subpage Code set to FFh indicate that the descriptor applies to all 
mode pages and subpages 

• MILUS (Multiple Logical Units Share) set to one indicates the policy is shared by multiple logical units. 

• Mode Page Policy set to 00b indicates that all mode pages and subpages are shared. 


HGST Hard Disk Drive OEM Specification 
92 




8.5.1.8 Inquiry Data Format - EVPD = 1, Page Code - 88h 


Table 81 Inquiry Data Format - EVPD = 1, (Page Code - 88h) 


Byte 

Bit 

765 

4 3 2 1 0 

0 

Qualifier = 0 

Peripheral Device Type = 0 

1 

Page Code = 88h 

2-3 

Page Length = 48 (0030h) 

4-5 

Reserved=0 

6-7 

Primary Relative Port = 0001 h 

8-9 

Reserved = 0 

10-11 

Initiator Port Transport ID Length = 0 

12-13 

Reserved = 0 

14-15 

Primary Target Port Descriptors Length = OCh 

16 

Protocol Identifier 

Code Set = 1 

17 

PIV=1 RSVD Association = 1 

Identifier Type = 3 

18 

Reserved = 0 

19 

Identifier Length = 8 

20-27 

(MSB) 

Primary Target Port Identifier (World Wide ID) 

(LSB) 

28-29 

Reserved = 0 

30-31 

Secondary Relative Port = 0002h 

32-33 

Reserved = 0 

34-35 

Initiator Port Transport ID Length = 0 

36-37 

Reserved = 0 

38-39 

Secondary Target Port Descriptors Length = OCh 

40 

Protocol Identifier Code Set = 1 

41 

PIV=1 RSVD Association = 1 Identifier Type = 3 

42 

Reserved = 0 

43 

Identifier Length = 8 

44-51 

(MSB) 

Secondary Target Port Identifier (World Wide ID) 

(LSB) 


• Protocol Identifier is valid only when PIV=1. Protocol Identifier = 0 indicates Fibre Channel devices. Protocol 
Identifier = 6 indicates SAS devices 

• Code Set specifies the data type for the identifier field. Code Set = 1 indicates binary data 

• PIV (Protocol Identifier Valid) set to one indicates that the Protocol Identifier field contains a valid value. 
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• Association specifies the entity with which the Identifier field is associated: 1 h for Target or Relative Port. 

• Identifier Type specifies the format and assignment authority for the identifier: 3h indicates NAA format of the 
WWID for Target Port. 

• Identifier fields contain the actual Identifier Descriptor. 

- The Target Port Identifiers are defined in the NAA IEE WWID format where: 

World Wide ID is a 64-bit unique identification for each drive. The format is: 5000CCAh 

xxxh n yyb where xxx is the 12-bit block assignment defined for each model and manufacturing site, n is the 

22-bit drive unique serial number, and yy is the 2-bit port/node ID 

8.5.1.9 Inquiry Data Format - EVPD = 1, Page Code - 8Ah 


Table 82 Inquiry Data Format - EVPD = 1, (Page Code - 8Ah) 


Byte 

Bit 

765 

4 3 2 1 0 

0 

Qualifier = 0 

Peripheral Device Type = 0 

1 

Page Code = 8Ah 

2-3 

Page Length = 14 (OOOEh) 

4 

Reserved=0 

STANDBYY 

STANDBYZ 

5 

Reserved=0 IDLE_C 

IDLEB 

IDLEA 

6-7 

Stopped Condition Recovery Time 

8-9 

Standby_Z Condition Recovery Time 

10-11 

Standby_Y Condition Recovery Time 

12-13 

ldle_A Condition Recovery Time 

14-15 

ldle_B Condition Recovery Time 

16-17 

ldle_C Condition Recovery Time 


Qualifier field is set to zero to indicate that the LUN specified in the Command Block is currently supported. 
Peripheral Device Type is set to zero to indicate that the device is Direct Access. 

Page Code is set to the value of the page code field in the CDB. 

Page Length is set to 14, and this field specifies the length of the following page data. 

If set to one, a power condition support bit (STANDBY_Y, STANDBY_Z, IDLE_C, IDLE_B, IDLE_A) indicates 
that the associated power condition may be entered with START STOP UNIT command and the associated 
power condition may be entered with a power condition timer if the timer is supported and enabled. 

The recovery time fields indicate the time, in one millisecond increments, that the logical unit takes to transition 
from the associated power condition to the active power condition. This time does not include the processing 
time for the command that caused this transition to occur. A value of zero indicates that the recovery time is not 
specified. A value of FFFFh indicates that the recovery time is more than 65.534 seconds. 
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8.5.1.10 Inquiry Data - EVPD = 1, Page Code - 90h 


Table 83 Inquiry Data - EVPD = 1 (Page Code = 90h) 


Byte 

Bit 

765 

4 3 2 1 0 

0 

Qualifier = 0 

Peripheral Device Type = 0 

1 

Page Code = 90h 

2-3 

Page Length = 24 (0018h) 

4-15 

Protocol-specific logical unit information descriptor 0. 

16-27 

Protocol-specific logical unit information descriptor 1. 


• Qualifier field is set to zero to indicate that the LUN specified in the Command Block is currently supported. 

• Peripheral Device Type is set to zero to indicate that the device is Direct Access. 

• Page Code is set to the value of the page code field in the CDB. 

• Page Length is set to 24, and this field specifies the length of the following page data. 

• Protocol-specific logical unit information descriptor 0 field is defined in Table 84 

• Protocol-specific logical unit information descriptor 1 field is defined in Table 84 


Table 84 

Protocol-specific logical unit information descriptor 


Byte 

Bit 

765 

4 3 2 1 

0 

0-1 

Relative Port Identifier 

2 

Reserved 

Protocol Identifier = 6h 

3-5 

Reserved 

6-7 

Descriptor Length (0004h) 

8 

Reserved 

TLR CONTROL 
SUPPORTED = Oh 

9-11 

Reserved 


• Relative Port Identifier is set to 1 for Port A (Primary Port) or 2 for Port B (Secondary Port). 

• Protocol Identifier is set to 6 to specify that this is a SAS SSP Descriptor. 

• TLR Control Supported field specifies support of the TLR CONTROL field in the SAS SSP frame header. This 
field is set to zero to indicate that the drive does not support Transport Layer Retries 


HGST Hard Disk Drive OEM Specification 
95 





8.5.1.11 Inquiry Data Format - EVPD = 1, Page Code - BOh 


Table 85 Inquiry Data - EVPD = 1 (Page Code = BOh) 



Bit 

Byte 

7 6 5 

4 3 2 1 0 

0 

Qualifier = 0 

Peripheral Device Type = 0 

1 

Page Code = BOh 

2-3 

Page Length = 60 (003Ch) 

4 

Reserved WSNZ=0 

5 

Maximum Compare and Write Length = 0 

6-7 

Optimal Transfer Length Granularity = 0 

8-11 

Maximum Transfer Length = 0 

12-15 

Optimal Transfer Length = 0 

16-19 

Maximum Prefetch XDRead XDWrite Transfer Length = 0 

20-23 

Maximum Unmap LBA Count = 0 

24-27 

Maximum Unmap Block Descriptor Count = 0 

28-31 

Optimal Unmap Granularity = 0 

32-35 

UGAVALID=0 

Unmap Granularity Alignment = 0 

36-43 

Maximum Write Same Length = 0 

44-63 

Reserved 


Qualifier: set to zero to indicate that the LUN specified in the Command Block is currently supported. 
Peripheral Device Type: set to zero to indicate that the device is Direct Access. 

Page Code: set to the value of the page code field in the CDB. 

Page Length: This field is set to 60 (3Ch), and specifies the length of the following page data. 

WSNZ - Write Same No Zero: set to zero which indicates the drive supports a value of zero in the NUMBER 
OF LOGICAL BLOCKS field in the WRITE SAME command CDB. 

Maximum Compare and Write Length: set to zero which indicates the drive does not support the COMPARE 
AND WRITE command. 

Optimal Transfer Length Granularity: set to zero to indicate that the drive does not report optimal transfer 
length granularity. 

Maximum Transfer Length: set to zero which indicates there is no reported limit on the maximum transfer 
length in logical blocks that the drive accepts for a single request using any of the following supported media 
access commands: PREFETCH, READ, VERIFY, WRITE, WRITE AND VERIFY. 

Optimal Transfer Length: set to zero which indicates there is no reported value for the optimal transfer length 
in logical blocks for any of the following supported media access commands: PREFETCH, READ, VERIFY, 
WRITE, WRITE AND VERIFY. 

Maximum Prefetch XDRead XDWrite Transfer Length: indicates the maximum transfer length in logical blocks 
that the drive accepts for a single PRE-FETCH command. It is set to zero to be less than or equal to the Maximum 
Transfer Length (above). 

Maximum Unmap LBA Count: set to 0000_0000h to indicate that the drive does not implement the UNMAP 
command. 

Maximum Unmap Block Descriptor Count: set to 0000_0000h to indicate that the drive does not implement 
the UNMAP command. 

Optimal Unmap Granularity: set to 0000_0000h to indicate that the optimal unmap granularity is not specified. 
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• UGAVALID - Unmap Granularity Alignment VALID: set to zero indicates that the UNMAP GRANULARITY 
ALIGNMENT field is not valid. 

• Unmap Granularity Alignment: set to zero and is not valid. 

• Maximum Write Same Length: set to zero which indicates that there is no reported limit on the number of 
logical blocks that may be requested for a single WRITE SAME command. 

8.5.1.12 Inquiry Data Format - EVPD = 1, Page Code - Blh 


Table 86 Inquiry Data - EVPD = 1 (Page Code = B lh) 


Byte 

Bit 

765 

4 3 2 1 0 

0 

Qualifier = 0 

Peripheral Device Type = 0 

1 

Page Code = B1 h 

2-3 

Page Length = 60 (003Ch) 

4-5 

Medium Rotation Rate 7200 (1C20h) 

6 

Reserved 

7 

WABEREQ WACEREQ Nominal Form Factor = 2h 

8-63 

Reserved 


• Qualifier field is set to zero to indicate that the LUN specified in the Command Block is currently supported. 

• Peripheral Device Type is set to zero to indicate that the device is Direct Access. 

• Page Code is set to the value of the page code field in the CDB. 

• Page Length is set to 60, and this field specifies the length of the following page data. 

• Medium Rotation Rate field is set to 7200. 

• Nominal Form Factor field is set to 2h. 

• WACEREQ If CryptoErase is supported then set WACEREQ to 01 b indicating. 
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8.5.1.13 Inquiry Data Format - EVPD = 1, Page Code - B2h 


Table 87 Inquiry Data - EVPD = 1 (Page Code = B2h) 


Byte 

Bit 

765 

4 3 2 1 0 

0 

Qualifier = 0 

Peripheral Device Type = 0 

1 

Page Code = B2h 

2-3 

Page Length = 4 (0004h) 

4 

Threshold Exponent = 0 

5 

LBPU=0 LBPWS= 0 LB ™ S1 

Reserved 

LBPRZ=0 ANC_SUP=0 DP=0 

6 

Reserved 

Provisioning Type = 1 

7 

Reserved 


Threshold Exponent: set to zero which indicates that the logical unit does not support logical block provisioning 
thresholds 

LBPU: set to 0 to indicate that the device does not support the UNMAP command. 

LBPWS: set to 0 to indicate that the device does not support the WRITE SAME (16) command to unmap LBAs. 
LBPWS10: set to 0 to indicate that the device does not support the WRITE SAME (10) command to unmap 
LBAs. 

LBPRZ: set to 0 to indicate that, for an unmapped LBA specified by a read operation, the drive may send user 
data with all bits set to any value to the Data-In Buffer 

ANC_SUP: set to 0 to indicate that the device does not support anchored LBAs. 

DP: set to 0 to indicate no Provisioning Group Descriptor is present 
Provisioning Type: set to 1 to indicate the logical unit is resource provisioned 
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8.5.1.14 Inquiry Data Format - EVPD = 1, Page Code - Dlh 


Table 88 Inquiry Data - EVPD = 1 (Page Code = Dlh) 


Byte 

Bit 

765 

4 3 2 1 0 

0 

Qualifier = 0 

Peripheral Device Type = 0 

1 

Page Code = Dlh 

2 

Reserved = 0 

3 

Page Length = 80 (50h) 

4-19 

ASCII Media Disk Definition 

20-35 

ASCII Motor Serial Number 

36-51 

ASCII Flex Assembly Serial Number 

52-67 

ASCII Actuator Serial Number 

68-83 

ASCII Device Enclosure Serial Number 


• Qualifier is set to zero to indicate that the LUN specified in the Command Block is currently supported. 

• Peripheral Device Type is set to zero to indicate that the device is Direct Access. 

• Page Code is set to the value of the page code field in the CDB. 

• Page Length is set to 80, and this field specifies the length of the following page data. 

Note: If the media is not available, bytes 0 through 3 are valid. All the other fields are ASCII blanks (20h). 
Note: All ASCII fields are alphanumeric, left aligned, and padded on the right with ASCII blanks (20h). 
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8.5.1.15 Inquiry Data Format - EVPD = 1, Page Code - D2h 


Table 89 Inquiry Data - EVPD = 1 (Page Code = D2h) 


Byte 

Bit 

765 

4 3 2 1 0 

0 

Qualifier = 0 

Peripheral Device Type = 0 

1 

Page Code = D2h 

2 

Reserved = 0 

3 

Page Length = 52 (34h) 

4 

HDC Version Length = 16 (lOh) 

5-20 

ASCII HDC Version 

21 

Card Serial Number Length = 16 (1 Oh) 

22-37 

ASCII Card Serial Number 

38 

Card Assembly Part Number Length = 16 (1 Oh) 

39-54 

ASCII Card Assembly Part Number 

55 

Reserved = 0 


• Qualifier is set to zero to indicate that the LUN specified in the Command Block is currently supported. 

• Peripheral Device Type is set to zero to indicate that the device is Direct Access. 

• Page Code is set to the value of the page code field in the CDB. 

• Page Length is set to 52, and this field specifies the length of the following page data. 

Note: If the media is not available, bytes 0 through 3 are valid. All the other fields are ASCII blanks (20h). 

Note: All ASCII fields are alphanumeric, left aligned, and padded on the right with ASCII blanks (20h). 
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8.6 Logical Depop Feature Set Command(FCh) 

8.6.1 Inquiry Depopulated Heads 

This command allows the initiator to retrieve information on heads depoped at command reception time and heads 
present at factory shipping time. The size of data sent to the initiator is always 8 bytes. 

Table 90 Inquiry Depopulated Heads 


Byte 

Bit 

7 6 5 4 3 21 0 

0 

Command Code =FCh 

1 

Feature=01h 

2-4 

Reserved 

5 

CONTROL 


Table 91 Heads status of depop and factory shipping 


Byte 

Bit 

7 1 6 1 5 1 4 1 3 1 2 1 1 1 ° 


Head depop status(head 23:0) 

Bit value 0: not depoped/ bit value 1: depoped 

0 

Head7 

Head6 

Head5 

Head4 

Head3 

Head2 

Headl 

HeadO 

1 

Head15 

Head14 

Head13 

Head12 

Headll 

HeadIO 

Head9 

Head8 

2 

Head23 

Head22 

Head21 

Head20 

Head19 

Head18 

Headl7 

Headl6 

3 

Reserved 


Head presence at factory shipping time(head 23:0) 

Bit value 0: Head not present/ bit value 1: head present 

4 

Head7 

Head6 

Head5 

Head4 

Head3 

Head2 

Headl 

HeadO 

5 

Head15 

Head14 

Head13 

Head12 

Headll 

HeadIO 

Head9 

Head8 

6 

Head23 

Head22 

Head21 

Head20 

Head19 

Head18 

Headl7 

Headl6 

7 

Reserved 


8.6.2 Format Unit with Depopulation 


This command initiates special format operation to exclude specified head(s) as not present. The number of logical 
blocks is reduced according to the number of physical blocks on surface(s) associated with excluded head(s). The 
format operation is performed in background. The initiator can use REQUEST SENSE to query progress of format 
operation 

Table 92 Format Unit with Depopulation 


Byte 

Bit 

7 

| 6 

5 

4 

1 3 

2 

1 

0 

0 

Command Code =FCh 

1 

Feature=02h 


Specified heads(Byte2-Byte4) 

2 

Head7 

Head6 

Head5 

Head4 

Head3 

Head2 

Headl 

HeadO 

3 

Headl5 

Headl4 

Headl3 

Headl2 

Headll 

HeadIO 

Head9 

Head8 

4 

Head23 

Head22 

Head21 

Head20 

Headl9 

Headl8 

Headl7 

Headl6 

5 

CONTROL 
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8.7 

LOG SELECT (4C) 


Table 93 

Log Select (4C) 



Byte 

Bit 

7 6 

5 4 3 2 

10 

0 

Command Code = 4Ch 

1 

Reserved = 0 

Reserved = 0 

PCR SP 

2 

PC 

Page Code 


3 

SubPage Code = 0 

4-6 

Reserved = 0 

7-8 

(MSB) 

Parameter List Length = 0 

(LSB) 

9 


Reserved = 0 

FLAG LINK 


The LOG SELECT command provides a means for the Initiator to clear statistical information maintained by the drive 
and reported via the LOG SENSE command. 

• PCR The Parameter Code Reset determines whether the Log Sense parameters will be cleared and unit 
attention posted for all other Initiators. A value of 1 indicates that the parameters be cleared, while a value of 
zero (except when PC = 11b) indicates that the parameters not be cleared. Parameter list length must be zero 
when PCR is I.The PC field is ignored for list parameters, i.e. when the Format and Linking (F&L) field contains 
01b or 11b. 

• SP The Save Parameters bit value of zero indicates that the page parameters not be saved. A value of 1 indicates 
that the page parameters that are savable be saved after they have been changed. SP bit MUST be 1 if 
parameter list length is greater than zero. Otherwise it will result in a Check Condition status being returned. The 
sense key shall be set to Illegal Request and additional sense code of Invalid Field in CDB. 

• PC The Page Control field defines the type of parameters to be selected. The PC field set to 11b (and PCR is 
then a don't care) indicates that the Default Cumulative values are set to their default values of 0. If the PC field 
is set to 01 b and PCR is set to 1, the Current Cumulative values are also set to their default values of 0. 

Parameter List Length MUST be zero when PC = 11b. Otherwise the command is terminated and a Check 
Condition status is returned. The sense key shall be set to Illegal Request and additional sense code of Invalid 
Field in CDB. 

• Page Code field identifies which page is being selected. This field must be set to the values indicated in Page 
0. If the Page Code value is invalid a Check Condition status is returned with a sense key of Illegal Request and 
additional sense code of Invalid Field in CDB. 

• If page code field is set to zero, then the selection applies to all log parameters in all valid log pages. 

• If page code field is set to a non zero, then the selection applies to all log parameters specified by this field. 

• SubPage Code This field specifies the subpage to select. This field is not supported and must be set to 0. 

• Parameter List Length The Parameter List Length field specifies the length in bytes of the parameter list that 
shall be located in the DATA OUT buffer. A parameter list length zero indicates that no pages shall be transferred. 

• If the PARAMETER LIST LENGTH field is set to zero, then the PCR bit, the SP bit, and the PC fields apply 
to the page (pages) addressed by the page code field. 

• If The PARAMETER LIST LENGTH field is set to non zero, and the if PAGE CODE field is non-zero or the 
SUBPAGE CODE field is non-zero, then the command shall be terminated with CHECK CONDITION status, 
with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 
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Note: A specified length greater than OxOOFF will result in a Check Condition status being returned. A length that 
results in log data being truncated will generate a Check Condition status. 

Note: For page OFh, the maximum parameter list length supported is 4004h (4 bytes for the header and lOOh bytes 
for each of the 40h parameters that are supported). The Parameter List Length must be an integral of the 
number of parameters plus the 4 byte header. (Ex: Parameter length =104h for one parameter, 204h for 2 
parameters,... 4004h for all 40h parameters). 

The drive allows updates to the current cumulative values only. A value of zero is acceptable and is not considered 
an error. 

The drive updates only pages OEh, the Start/Stop Cycle page and OFh, the Application Client page. For other pages 
the parameters are ignored. If the data out buffer contains multiple pages then the application client should send the 
pages in ascending order. If the data out buffer contains multiple log parameters within a page, all log parameters 
within the page should be sent and they should be sent in ascending order by parameter code value. The drive shall 
return Check Condition status if the application client sends pages out of order, parameter codes out of order or 
missing parameter code. The sense key shall be set to Illegal Request and additional sense code set to Invalid Field 
in Parameter List. If one or more fields of the CDB are not set correctly the command will be terminated with a Check 
Condition status. The sense key shall be set to Illegal Request and additional sense code of Invalid Field in CDB. To 
indicate that parameters have changed, the Target generates a unit attention condition for all Initiators except the one 
that issued the LOG SELECT command. 

The following list contains all individual page parameters (counters) that are set to their default value of zero by the 
LOG SELECT command (when PCR=1). 

• Page 02h parameters: (Counters for write errors) 

- Write errors recovered without delay 

- Write errors recovered with possible delays 

- LBAs with write fault error 

- Reserved=0 

- Total errors recovered 

- Number of times recovery invoked 

- Total write byte count 

- LBAs with hard error 

• Page 03h parameters: (Counters for read errors) 

- Read errors recovered without delay 

- Read errors recovered with possible delays 

- LBAs with LDPC detected error 

- Reserved=0 

- Total errors recovered 

- Number of times recovery invoked 

- Total read byte count 

- LBAs with hard error 

• Page 05h parameters: (Counters for Verify Errors) 

- Errors recovered without delay 

- Errors recovered with possible delays 

- LBAs with LDPC detected error 

- Reserved=0 

- Total errors recovered 

- Number of times recovery invoked 

- Total bytes verified 

- LBAs with hard error 
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Page 06h parameters: (Counters for non medium errors, seek and other hardware type failures) 

- Non-Medium Error Counter 

Page 15h parameters: (Background Medium Scan information) 

- BMS Status parameter 

- all Medium Scan parameters 

Page 18h parameters (SAS PHY Error counts - only cleared for the port which receives the Log Select) 

- Invalid DWORD Count 

- Running Disparity Error Count 

- Loss of DWORD Synchronization Count 

- PHY Reset Problem Count 
Page 30h parameters: 

- Zero Seeks counter 

- Seeks > = to 2/3 counter 

- Seeks > = 1/3 and < 2/3 counter 

- Seeks > = 1/6 and < 1/3 counter 

- Seeks > = 1/12 and < 1/6 counter 

- Seeks > 0 and <1/12 counter 

- Overrun Counter 

- Linder run Counter 

- Device Cache Full Read Hits 

- Device Cache Partial Read Hits 

- Device Cache Write Hits 

- Device Cache Fast Writes 

- Device Cache Misses on Reads 
Page 37h parameters: 

- Media EXC 

- Hardware EXC 

- Total Read Commands 

- Total Write Commands 
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8.8 LOG SENSE (4D) 


Table 94 Log Sense (4D) 


Byte 

Bit 

7 6 5 4 3 21 0 

0 

Command Code = 4Dh 

1 

Reserved = 0 Reserved = 0 PPC=0 SP 

2 

PC Page Code 

3 

Subpage Code = 0 

4 

Reserved = 0 

5-6 

(MSB) 

Parameter Pointer 

(LSB) 

7-8 

(MSB) 

Allocation Length 

(LSB) 

9 

Reserved = 0 FLAG LINK 


The LOG SENSE command allows the Initiator to retrieve the statistical data regarding the drive. 

• PPC (Parameter Pointer Control) bit must be set to zero. This specifies that the drive start transferring data 
starting from the field specified in the parameter pointer field for the number of bytes specified by the allocation 
length. If the PPC bit is set to 1, Check Condition status is returned with a sense key of Illegal Request and 
additional sense code of Invalid Field in CDB. 

• SP (Save Parameters) bit set to 0 specifies that the drive does not save any log parameters. If it is set to 1, all 
page parameters that are savable (those pages denoted by a DS = 0 in the parameter header control byte) are 
saved. 

• PC (Page Control) field defines the type of parameters to be selected. This field must be set to 01b to specify 
the current cumulative values. Any other value in this field will cause the command to end with a Check Condition 
status with a sense key of Illegal Request and an additional sense code of Invalid Field in CDB. 

• Page Code field identifies which page is being requested. This field must be set to the values indicated in Page 
0. If the Page Code value is invalid a Check Condition status is returned with a sense key of Illegal Request and 
additional sense code of Invalid Field in CDB. 

• SubPage Code This field specifies the subpage to select. This field is not supported and must be set to 0. 

• Parameter Pointer Field specifies the beginning field for the transfer. This field must be set to OOOOh. If the 
Parameter Pointer Field is not zero a Check Condition status is returned with a sense key of Illegal Request and 
additional sense code of Invalid Field in CDB. 

• Allocation Length field specifies the maximum number of bytes the Initiator has allocated for returned Log 
Sense Data. No bytes are transferred if the length is zero. This condition is not considered an error. The Target 
terminates the Data in phase when all available Log Sense data has been transferred or when the number of 
bytes equals the allocation length, whichever is less. 
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8.8.1 Log Page parameters 

Each log page begins with a 4-byte page header followed by zero or more variable-length log parameters. 

Page header 

Page Code field identifies which log page is being transferred. 

The Page Length field specifies the length in bytes of the following log parameters. 

Log parameters 

Each log parameter begins with a 4-byte parameter header followed by one or more bytes of parameter value data. 
The Parameter Code field identifies which log parameter is being transferred for that log page. 

The Parameter Control field, the 3rd byte of each parameter header, contains several fields. 

- DU The Disable Update bit is set to 0 to indicate that the drive updates the log parameter value to reflect events 
that should be noted by that parameter. 

- TSD The Target Save Disable bit is set to zero to indicate that the drive provides a Target defined method for 
saving log parameters. 

- ETC The enable Threshold Comparison bit is set to 0 to indicate the drive does not perform comparisons between 
cumulative and any threshold values. 

- TMC The Threshold Met Criteria field is not valid because this drive does not perform threshold comparisons. This 
field is set to 0. 

- Format and Linking The F & L field indicates the type of log parameter and how parameters that reach their 
maximum value are handled. 

- 00b: Data counter: If any other parameter in this log page reaches its maximum value, then this parameter 
shall stop incrementing until reinitialized by a Log Select command. 

- 01b: List format ASCII data: No maximum values to handle 

- 10b: Data counter: If another parameter reported in this log page reaches its maximum value, then this 
parameter shall not stop incrementing. This parameter may be reinitialized by a Log Select command. 

- 11 b: List format binary data: No maximum values to handle. 
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8.8.2 Log Sense Page 0 

Page 0 indicates the supported log sense pages. This page is used to determine which additional pages and Initiator 
can request. 

Table 95 Log Sense Page 0 


Byte 

Bit 

7 6 

5 | 4 | 3 | 2 | 1 | 0 

0 

Reserved 

Page code = 0 

1 

Reserved 

2-3 

Page Length = 000E(Number of Pages Supported) 

4 

First supported page OOh 

5 

Second supported page 02h 

6 

Third supported page 03h 

7 

Fourth supported page 05h 

8 

Fifth supported page 06h 

9 

Sixth supported page ODh 

10 

Seventh supported page OEh 

11 

Eighth supported page OFh 

12 

Ninth supported page 10h 

13 

Tenth supported page 15h 


Eleventh supported page 18h 

14 

Twelfth supported page 2Fh 

15 

Thirteenth supported Page Code =30h 

16 

Fourteenth supported Page Code = 37h 
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8.8.3 Log Sense Page 2 


This page contains counters for write errors. 
Table 96 Log Sense Page 2 


Byte 

Bit 

7 | 6 

5 | 4 | 3 | 2 | 1 | 0 

0 

Reserved 

Page code = 02h 

1 

Reserved 

2-3 

Page Length = 54h 

4-5 

Parameter Code = OOOOh 

6 

DU=0 DS=0 TSD=0 ETC=0 TMC=0 F&L=00b 

7 

Parameter Length = 08h 

8-15 

Errors recovered without delay 

16-17 

ParameterCode = 0001 h 

18 

DU=0 DS=0 TSD=0 ETC=0 TMC=0 F&L=00b 

19 

Parameter Length = 08h 

20-27 

Errors recovered with possible delays 

28-29 

Parameter Code = 0002h 

30 

DU=0 DS=0 TSD=0 ETC=0 TMC=0 F&L=00b 

31 

Parameter Length = 08h 

32-39 

Reserved = 0 

40-41 

Parameter Code = 0003h 

42 

DU=0 DS=0 TSD=0 ETC=0 TMC=0 F&L=00b 

43 

Parameter Length = 08h 

44-51 

Total errors recovered 

52-53 

Parameter Code = 0004h 

54 

DU=0 DS=0 TSD=0 ETC=0 TMC=0 F&L=00b 

55 

Parameter Length = 08h 

56-63 

Times recovery invoked 

64-65 

Parameter Code = 0005h 

66 

DU=0 DS=0 TSD=0 ETC=0 TMC=0 F&L=00b 

67 

Parameter Length = 08h 

68-75 

Total bytes written 

76-77 

Parameter Code = 0006h 

78 

DU=0 DS=0 TSD=0 ETC=0 TMC=0 F&L=00b 

79 

Parameter Length = 08h 

80-87 

Count of hard errors 


All parameter counts indicate the number of sectors with the specified types of errors, except Times Recovery Invoked, 
which is a cumulative count of all recovery steps attempted on all sectors written. 
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8.8.4 Log Sense Page 3 


This page contains counters for read errors. 
Table 97 Log Sense Page 3 


Byte 

Bit 

7 | 6 

5 | 4 | 3 | 2 | 1 | 0 

0 

Reserved 

Page code = 03h 

1 

Reserved 

2-3 

Page Length = 54h 

4-5 

Parameter Code = OOOOh 

6 

DU=0 DS=0 TSD=0 ETC=0 TMC=0 F&L=00b 

7 

Parameter Length = 08h 

8-15 

Errors recovered without delay 

16-17 

Parameter Code = 0001 h 

18 

DU=0 DS=0 TSD=0 ETC=0 TMC=0 F&L=00b 

19 

Parameter Length = 08h 

20-27 

Errors recovered with possible delays 

28-29 

Parameter Code = 0002h 

30 

DU=0 DS=0 TSD=0 ETC=0 TMC=0 F&L=00b 

31 

Parameter Length = 08h 

32-39 

Reserved = 0 

40-41 

Parameter Code = 0003h 

42 

DU=0 DS=0 TSD=0 ETC=0 TMC=0 F&L=00b 

43 

Parameter Length = 08h 

44-51 

Total errors recovered 

52-53 

Parameter Code = 0004h 

54 

DU=0 DS=0 TSD=0 ETC=0 TMC=0 F&L=00b 

55 

Parameter Length = 08h 

56-63 

Times recovery invoked 

64-65 

Parameter Code = 0005h 

66 

DU=0 DS=0 TSD=0 ETC=0 TMC=0 F&L=00b 

67 

Parameter Length = 08h 

68-75 

Total bytes read 

76-77 

Parameter Code = 0006h 

78 

DU=0 DS=0 TSD=0 ETC=0 TMC=0 F&L=00b 

79 

Parameter Length = 08h 

80-87 

Count of hard errors 


All parameter counts indicate the number of sectors with the specified types of errors, except Times Recovery Invoked, 
which is a cumulative count of all recovery steps attempted on all sectors read. LDPC-on-the-fly correction is not 
included in any counters. 
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8.8.5 Log Sense Page 5 


This page contains counters for verify errors. 
Table 98 Log Sense Page 5 


Byte 

Bit 

7 | 6 

5 | 4 | 3 | 2 | 1 | 0 

0 

Reserved 

Page code = 05h 

1 

Reserved 

2-3 

Page Length = 54h 

4-5 

Parameter Code = OOOOh 

6 

DU=0 DS=0 TSD=0 ETC=0 TMC=0 F&L=00b 

7 

Parameter Length = 08h 

8-15 

Errors recovered without delay 

16-17 

Parameter Code = 0001 h 

18 

DU=0 DS=0 TSD=0 ETC=0 TMC=0 F&L=00b 

19 

Parameter Length = 08h 

20-27 

Errors recovered with possible delays 

28-29 

Parameter Code = 0002h 

30 

DU=0 DS=0 TSD=0 ETC=0 TMC=0 F&L=00b 

31 

Parameter Length = 08h 

32-39 

Reserved = 0 

40-41 

Parameter Code = 0003h 

42 

DU=0 DS=0 TSD=0 ETC=0 TMC=0 F&L=00b 

43 

Parameter Length = 08h 

44-51 

Total errors recovered 

52-53 

Parameter Code = 0004h 

54 

DU=0 DS=0 TSD=0 ETC=0 TMC=0 F&L=00b 

55 

Parameter Length = 08h 

56-63 

Times recovery invoked 

64-65 

Parameter Code = 0005h 

66 

DU=0 DS=0 TSD=0 ETC=0 TMC=0 F&L=00b 

67 

Parameter Length = 08h 

68-75 

Total Bytes Verified 

76-77 

Parameter Code = 0006h 

78 

DU=0 DS=0 TSD=0 ETC=0 TMC=0 F&L=00b 

79 

Parameter Length = 08h 

80-87 

Count of hard errors 


All parameter counts indicate the number of sectors with the specified types of errors, except Times Recovery Invoked, 
which is a cumulative count of all recovery steps attempted on all sectors verified. LDPC-on-the-fly correction is not 
included in any counters. 
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8.8.6 Log Sense Page 6 

This page contains counters for non-medium errors. This includes seek errors and other hardware type failures. 
Table 99 Log Sense Page 6 


Byte 

Bit 

7 | 6 

5 | 4 | 3 | 2 | 1 | 0 

0 

Reserved 

Page code = 06h 

1 

Reserved 

2-3 

Page Length = OCh 

4-5 

Parameter Code = OOh 

6 

DU=0 DS=0 TSD=0 ETC=0 TMC=0 F&L=00b 

7 

Parameter Length = 08h 

8-15 

Error count 


8.8.7 Log Sense Page D 


This page contains temperature information. 
Table 100 Log Sense Page D 


Byte 

Bit 

7 | 6 

5 | 4 | 3 | 2 | 1 | 0 

0 

Reserved 

Page code = ODh 

1 

Reserved 

2-3 

Page Length = OCh 

4-5 

Parameter Code = OOOOh 

6 

DU=0 DS=1 TSD=0 ETC=0 TMC=0 F&L=00b 

7 

Parameter Length = 02h 

8 

Reserved 

9 

Temperature (degrees Celsius) 

10-11 

Parameter Code 0001 h 

12 

DU=0 DS=1 TSD=0 ETC=0 TMC=0 F&L=00b 

13 

Parameter Length = 02h 

14 

Reserved 

15 

Reference Temperature (degrees Celsius) 
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8.8.8 Log Sense Page E 


This page contains the start-stop cycle information. 
Table 101 Log Sense Page E 


Byte 

Bit 

7 | 6 

5 | 4 | 3 | 2 | 1 | 0 

0 

Reserved 

Page code = OEh 

1 

Reserved 

2-3 

Page Length = 34h 

4-5 

Parameter Code = 0001 h 

6 

DU=0 DS=1 TSD=0 ETC=0 TMC=0 F&L=00b 

7 

Parameter Length = 06h 

8-11 

Year of Manufacture (4 ASCII characters) 

12-13 

Week of Manufacture (2 ASCII characters) 

14-15 

Parameter Code 0002h 

16 

DU=0 DS=0 TSD=0 ETC=0 TMC = 0 F&L = 00b 

17 

Parameter Length = 06h 

18-21 

Accounting Date Year (4 ASCII characters) 

22-23 

Accounting Date Week (2 ASCII characters) 

24-25 

Parameter Code 0003h 

26 

DU=0 DS=1 TSD=0 ETC=0 TMC = 0 F&L = 00b 

27 

Parameter Length = 04h 

28-31 

Specified cycle count over device lifetime 

32-33 

Parameter Code 0004h 

34 

DU=0 DS=1 TSD=0 ETC=0 TMC = 0 F&L = 00b 

35 

Parameter Length = 04h 

36-39 

Accumulated start-stop cycles (4 byte binary number) 

40-41 

Parameter Code 0005h 

42 

DU=0 DS=1 TSD=0 ETC=0 TMC = 0 F&L = 00b 

43 

Parameter Length = 04h 

44-47 

Specified load unload count over device lifetime 

48-49 

Parameter Code 0006h 

50 

DU=0 DS=1 TSD=0 ETC=0 TMC = 0 F&L = 00b 

51 

Parameter Length = 04h 

52-55 

Accumulated load unload cycles (4 byte binary number) 


The week and year that the device was manufactured shall be set in the parameter field defined by parameter code 
0001 h. The date of manufacture cannot be saved using the LOG SELECT command. The data is expected in numeric 
ASCII characters (30-39h) in the form YYYYWW. The accounting date specified by parameter code 0002h is a 
parameter that can be saved using the LOG SELECT command. 
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8.8.9 Log Sense Page F 


This page contains the Application Client Log. 
Table 102 Log Sense Page F 


Byte 

Bit 

7 | 6 

5 | 4 | 3 | 2 | 1 | 0 

0 

Reserved 

Page code = OFh 

1 

Reserved 

2-3 

Page length = 4000h 

Application client log parameter 

4-259 1st application client log parameter 


The following table describes the application client log parameter structure. 
Table 103 Log Sense Page F, Application Client Log 


Byte 

Bit 

7 1 6 1 5 | 4 | 3 | 2 | 1 | 0 

0-1 

Parameter code 

2 

DU=1 DS=0 TSD=0 ETC=0 TMC=0 F&L=00b 

3 

Parameter length = FCh 

4- 

First parameter byte 



255 

Last parameter byte 


Parameter code OOOOh through 003Fh are supported. 

The values stored in the parameter bytes represent data sent to the device in a previous LOG SELECT command. 
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8.8.10 Log Sense Page 10 

This page contains self-test results. The results of the 20 most recent self-tests are stored in this Log page. 
Table 104 Log Sense Page 10 


Byte 

Bit 

7 6 

5 | 4 | 3 | 2 | 1 | 0 

0 

Reserved 

Page code = 10h 

1 

Reserved 

2-3 

Page Length = 190h 

4-23 

1st self-test results log parameter 


384- 403 20th self-test results log parameter 


The following table describes the self-test results log parameter structure 
Table 105 Log Sense Page 10, self-test results 


Byte 

Bit 

7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 

0-1 

Parameter code 

2 

DU=0 DS=0 TSD=0 ETC=0 TMC=0 F&L=11b 

3 

Parameter Length = 10h 

4 

Function Code RSVD Self-Test Results Value 

5 

Extended Segment Number 

6-7 

Timestamp 

8-15 

LBAof First Failure 

16 

Reserved Sense Key 

17 

Additional Sense Code 

18 

Additional Sense Code Qualifier 

19 

Vendor specific 


Parameter Code identifies the log parameter for the log page. The parameter code field for the results of the 
most recent test will be 0001 h. The parameter for the next most recent will be 0002h. 

Function Code contains the content of the Function Code field in the SEND DIAGNOSTIC command that 
initiated this self-test. 

Self-Test Results Value is described in the table below. 
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Table 106 Log Sense Page 10, self-test results 


Value 

Description 

Oh 

The self-test routine completed without error. 

1h 

The background self-test routine was aborted by the initiator using a SEND DIAGNOSTIC command 
with the Abort Background self-test function. 

2h 

The self-test routine was aborted by the application client by a Task Management function or a reset. 

3h 

An unknown error occurred while the Target was executing the self-test routine and the Target was 
unable to complete the self-test routine. 

4h 

The self-test completed with a test element that failed and it is not known which test element failed. 

5h 

The first segment of the self-test failed. 

6h 

The second segment of the self-test failed. 

7h 

The third or greater segment of the self-test failed (see the Extended segment number field). 

8h-Eh 

Reserved. 

Fh 

The self-test is in progress. 


• Extended Segment Number This field identifies the number of the segment that failed during self-test. If no 
segment failed, this field will be OOh. 

Table 107 Log Sense Page 10, Extended Segment Number 


Extended 

Segment Number 

Short Self-Test 

Extended Self-Test 

1h 

Drive Ready Test 

2h 

Drive Diagnostics 

3h 

SMART 

4h 

Low Level Format check 

5h 

Physical Head Check 

7h 

- Verify First 300 MB 

- Verify Last 100 MB 

Verify all LBAs 

8h 

Recheck SMART 


• Timestamp This field contains the total accumulated power-on hours of the Target at the time the self-test 
completed. 

• LBA of first failure This field contains the LBA of the first logical block address where a self-test error occurred. 
If no errors occurred during the self-test or the error is not related to a LBA then the field will be 
FFFFFFFFFFFFFFFFh. 

• Sense Key, Additional Sense Code and Additional Sense Code Qualifier These fields will contain the 
additional information relating to the error or exception conditions during self-test. 

See Section 8.42 "SEND DIAGNOSTIC (ID)”, for detailed listing of operations carried out by SEND DIAGNOSTIC 
command and Power on Diagnostics. 
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8.8.11 Log Sense Page 15 


This page contains information about Background Medium Scan operations. 
Table 108 Log Sense Page 15 


Byte 

Bit 

7 6 

5 | 4 | 3 | 2 | 1 | 0 

0 

Reserved 

Page code = 15h 

1 

Reserved 

2-3 

Page Length = (19 + 24N -3) 


Background Medium Scan parameters 

4-19 

BMS Status Parameter 

20-43 

First Medium Scan Parameter 



19+24N 

Last Medium Scan Parameter 


The following table describes the BMS Status Parameter structure. 
Table 109 BMS Status Parameter structure 


Byte 

Bit 

7 | 6 5 | 4 3 | 2 Pi 1 0 

0-1 

Parameter Code = OOOOh 

2 

DU=0 DS=0 TSD=0 ETC=0 TMC=0 F&L = 11b 

3 

Page Length = OCh 

4-7 

Power On Minutes 

8 

Reserved = 0 

9 

BMS Status 

10-11 

Number of Background Scans Performed 

12-13 

Medium Scan Progress 

14-15 

Number of Background Medium Scans Performed 


• Power On Minutes indicates the total power on minutes at the time the log page is requested 

• BMS Status is described in the following table 
Table 110 BMS Status 


BMS Status 

Description 

OOh 

No scans active 

01 h 

Background medium scan is active 

03h-04h 

Not supported 

05h 

Background scan halted due to medium formatted without P-List 

06h 

Background scan halted due to a vendor-specific cause 

07h 

Background scan halted due to temperature out of range 

08h 

Scan suspended until BMS Interval Timer expires 

09h - FFh 

Reserved 


The Number of Background Scans Performed field indicates the total number of back ground scans (i.e. total 
number of Background Medium Scans PLUS number of Background Prescan) that have been performed over 
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the life of the drive. 

Medium Scan Progress is a percent complete indication of the medium scan. The returned value is a numerator 
that has 65,536(1 00 OOh) as its denominator. 

Number of Background Medium Scans Performed field indicates the number of background mediumscans 
that have been performed over the life of the drive. 


The following table describes the Medium Scan Parameter structure. 
Table 111 Medium Scan Parameter structure 


Byte 

Bit 

7 6 5 4 3 21 0 

0-1 

Parameter Code = 0001 h - 0800h 

2 

DU=0 DS=0 TSD=0 ETC=0 TMC=0 F&L = 11b 

3 

Page Length = 14h 

4-7 

Power On Minutes 

8 

Reassign Status Sense Key 

9 

Additional Sense Code 

10 

Additional Sense Code Qualifier 

11 

Head (MSB) Cylinder 

12-13 

(MSB) 

Cylinder 

(LSB) 

14-15 

(MSB) 

Sector 

(LSB) 

16-23 

LBA 


• Power On Minutes indicates the total power on minutes at the time the error was detected. 

• Reassign Status is set as shown below. Reassignment during the background scan is not supported. 
Table 112 Reassign Status 


Reassign Status 

Description 

Oh 

No reassignment needed 

This value is not reported, if LOWIR bit is set to 1 in Background Control Mode Page. 

1h 

Reassignment pending receipt of Reassign command or write command (if auto write 
reallocation is allowed) from the initiator 

02h-4h 

Not supported 

5h 

Error was detected by BGMS, and was successfully rewritten. 

This value is not reported, if LOWIR bit is set to 1 in Background Control Mode Page. 

6h 

Error was detected by BGMS, and was successfully reassigned by Application Client. 
Contains valid data. 

7h - Fh 

Reserved 


Additional Sense Code and Additional Sense Code Qualifier provide details about the error detected. 
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8.8.12 Log Sense Page 18 


This page contains protocol-specific log parameters. 
Table 113 Log Sense Page 18 


Byte 

Bit 

7 6 5 4 3 21 0 

0 

Page code = 18h 

1 

SubPage Code (OOh) 

2-3 

(MSB) 

Page Length (D8h) 

(LSB) 

Protocol-specific log parameters 

4-111 

First Protocol-specific log parameter - Primary Port 

112-219 

Last Protocol-specific log parameters - Secondary Port 


Table 114 SAS Log Descriptor (part 1 of 3) 


Byte 

Bit 

7 

1 6 1 5 1 4 

3210 

0-1 

(MSB) 

Parameter Code (0001 h for primary port; 0002h for secondary 

(LSB) 

2 

DU (=0) 

Obsolete TSD (=0) ETC (=0) 

TMC (00b) Format and Linking 

3 

Parameter Length (68h) 

4 


Reserved 

Protocol IDENTIFIER (6h) 

5 

Reserved 

6 

Generation Code 

7 

Number of PHYs (01 h) 

8 

Reserved 

9 

PHY IDENTIFIER (OOh) 

10 

Reserved 

11 

SAS PHY Log Descriptor Length (60h) 

12 

Reserved 

Attached Device Type 

Attached Reason 

13 

Reason 

Negotiated Physical Link Rate 
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Table 115 SAS Log Descriptor (part 2 of 3) 


Byte 

Bit 

7 6 5 4 

3 

2 

1 

0 

14 

Reserved 

Attached SSP 
Initiator Port 

Attached STP 
Initiator Port 

Attached SMP 
Initiator Port 

Reserved 

15 

Reserved 

Attached SSP 
Target Port 

Attached STP 
Target Port 

Attached SMP 
Target Port 

Reserved 

16-23 

(MSB) 

SAS Address (the address of the target port) 

(LSB) 

24-31 

(MSB) 

Attached SAS Address (the address received in the incoming IDENTIFY) 

(LSB) 

32 

Attached PHY Identifier 

(the PHY identifier received in the incoming IDENTIFY) 

33-39 

Reserved 

40-43 

(MSB) 

Invalid Dword Count 

(LSB) 

44-47 

(MSB) 

Running Disparity Error Count 

(LSB) 

48-51 

(MSB) 

Loss of Dword Synchronization 

(LSB) 

52-55 

(MSB) 

PHY Reset Problem 

(LSB) 

56-57 

Reserved 

58 

PHY event Descriptor Length (OCh) 

59 

Number of Event Descriptors (04h) 

60-62 

Reserved 

63 

Phy Event Source (01 h) (Invalid Dword Count) 

64-67 

(MSB) 

PHY Event 

(LSB) 

68-71 

(MSB) 

Peak Value Detector Threshold (OOh) 

(LSB) 
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Table 116 SAS Log Descriptor (part 3 of 3) 


Byte 

Bit 

7 6 5 4 3 21 0 

72-74 

Reserved 

75 

PHY Event Source (02h) 

(Running Disparity Error Count) 

76-79 

(MSB) 

PHY Event 

(LSB) 

80-83 

(MSB) 

Peak Value Detector Threshold (OOh) 

(LSB) 

84-86 

Reserved 

87 

PHY Event Source (03h) 

(Loss of Dword Sync) 

88-91 

(MSB) 

PHY Event 

(LSB) 

92-95 

(MSB) 

Peak Value Detector Threshold (OOh) 

(LSB) 

96-98 

Reserved 

99 

PHY Event Source (04h) 

(PHY Reset Problem) 

100-103 

(MSB) 

PHY Event 

(LSB) 

104-107 

(MSB) 

Peak Value Detector Threshold (OOh) 

(LSB) 


Attached Device Type: set to the value received by this PHY during an Identify Sequence. 

Attached Reason: If the phy is a physical phy and a SAS phy or expander phy is attached, then the ATTACHED 
REASON field indicates the value of the REASON field in the last received IDENTIFY address frame (see Table 
33) during the identification sequence. If the phy is a physical phy and a SATA phy is attached, then the 
ATTACHED REASON field shall be set to Oh after the initial Register - Device to Host FIS has been received. If 
the phy is a virtual phy, then the ATTACHED REASON field shall be set to Oh. 

Reason: The REASON field indicates the reason for the last link reset sequence as reported in the last 
transmitted IDENTIFY address frame, (see Table 33). If the phy is a physical phy and a SATA phy is attached, 
then the REASON field indicates the reason for the link reset sequence. For Reason field, refer Table 34. 
Negotiated PHY Link Rate: set to the link rate negotiated during last Link Reset Sequence. 

- set to 8h when the PHY is enabled and the negotiated speed is 1.5G 

- set to 9h when the PHY is enabled and the negotiated speed is 3.0G 

- set to Ah when the PHY is enabled and the negotiated speed is 6.0G 
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The GENERATION CODE field is a one-byte counter that shall be incremented by one by the drive every time 
the values in this mode page or the SAS-2 Phy mode page field values are changed. A GENERATION CODE 
field set to OOh indicates the generation code is unknown. The drive shall wrap this field to 01 h as the next 
increment after reaching its maximum value (i.e., FFh). The GENERATION CODE field is also contained in the 
Protocol-Specific Port log page and may be used to correlate phy settings across mode page and log page 
accesses. 

Attached Reason: indicates the value of the REASON field received in the IDENTIFY address frame. 

Attached Initiator Port bits: set to the value received by this PHY during an Identify Sequence. 

Attached Target Port: set to the value received by this PHY during an Identify Sequence. 

SAS ADDRESS: field contains the SAS address transmitted by this PHY during an Identify Sequence. 
Attached SAS ADDRESS: field contains the SAS address received by this PHY during an Identify Sequence. 
Attached PHY Identifier: field contains the SAS PHY Identifier received by this PHY during an Identify 
Sequence. 

INVALID DWORD COUNT : indicates the number of invalid DWords that have been received outside of phy reset 
sequences. The count wraps at the maximum value. 

RUNNING DISPARITY ERROR COUNT: RUNNING DISPARITY ERROR COUNT increments by one when the 
port has acquired dword synchronization and detects a transmission word containing a running disparity error at 
the receiver. When the port has lost dword synchronization, the Running Disparity Error Count is not incremented. 
The count stops at the maximum value. 

LOSS OF DWORD SYNCRONIZATION: indicates the number of times the phy has lost dword synchronization 
and restarted the link reset sequence of phy reset sequences. The count wraps at the maximum value. 

PHY RESET PROBLEM: indicates the number of times the phy reset sequence has failed due to a failure to 
gain dword sync in the retry speed match speed negotiation. The count wraps at the maximum value. 
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8.8.13 Log Sense Page 19h - General Statistics and Performance 


Table 117 Log Sense Page 19h - General Statistics and Performance 


Byte 

Bit 

7 

6 

5 4 3 2 1 0 

0 

DS = 0 

SPF = 0 

Page Code = 19h 

1 

Sub Page Code = OOh 

2-3 

Page Length = 005Ch 

4-5 

Parameter Code = 0001 h 

6 

DU = 0 Obsolete TSD = 0 ETC = 0 TMC = 0 Format and Linking = 10b 

7 

Parameter Length = 40h 

8-15 

Number of Read Commands 

16-23 

Number of Write Commands 

24-31 

Number of Logical Blocks Received 

32-39 

Number of Logical Blocks Transmitted 

40-47 

Read Command Processing Intervals 

48-55 

Write Command Processing Intervals 

56-63 

Weighted Number of Read Commands plus Write Commands 

64-71 

Weighted Read Command Processing plus Write Command Processing 

72-73 

Parameter Code = 0002h 

74 

DU = 0 Obsolete TSD = 0 ETC = 0 TMC = 0 Format and Linking = 10b 

75 

Parameter Length = 08h 

76-83 

Idle Time Intervals 

84-85 

Parameter Code = 0003h 

86 

DU = 0 Obsolete TSD = 0 ETC = 0 TMC = 0 Format and Linking = 11b 

87 

Parameter Length = 08h 

88-95 

Time Interval Descriptor 


Number of Read Commands indicates the number of read commands received by the logical unit. 

Number of Write Commands indicates the number of write commands received by the logical unit. 

Number of Logical Blocks Received indicates the number of logical blocks received by any SCSI target port 
for the logical unit as a result of write commands. 

Number of Logical Blocks Transmitted indicates the number of logical blocks transmitted by any SCSI target 
port for the logical unit as a result of read commands. 

Read Command Processing Interval is not supported and is set to 0. 

Write Command Processing Interval is not supported and is set to 0. 

Weighted Number of Read Commands Plus Write Commands is not supported and is set to 0. 

Weighted Read Command Processing Plus Write Command Processing is not supported and is set to 0. 
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• Idle Time Intervals indicates the cumulative number of idle times spent while there are no commands in the 
task set and there are no commands being processed by the logical unit. 

Idle time is calculated using the time interval in parameter 0003h: 
idle time = (time increments not processing commands x time interval) 

The time interval descriptor contains the time interval in seconds. 

Table 118 Time Interval Descriptor 


Byte 

Bit 

7 6 5 4 3 21 0 

0-3 

Exponent 

4-7 

Integer 


• Exponent contains the negative power of 10 exponent to multiply with the Integer field. 

• Integer, when multiplied by the exponent, contains the value that represents one time interval. 
The Exponent and Integer are set to the equivalent of 50ms (5x10 2 seconds). 
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8.8.14 Log Sense Page 1A 


Table 119 Log Sense Page 1A 


Byte 

Bit 

7 6 

5 4 3 2 1 0 

0 

Reserved 

Page code = 1Ah 

1 

Sub Page Code (OOh) 

2-3 

Page Length (30h) 

4-5 

Parameter Code 0001 h 

6 

DU Obsolete TSD ETC TMC TMC FMT & Linking FMT & Linking 

7 

Parameter Length = 4 

8-11 

Accumulated Transitions to Active State 

12-13 

Parameter Code 0002h 

14 

DU Obsolete TSD ETC TMC TMC FMT & Linking FMT & Linking 

15 

Parameter Length = 4 

16-19 

Accumulated Transitions to ldle_A 

20-21 

Parameter Code 0003h 

22 

DU Obsolete TSD ETC TMC TMC FMT & Linking FMT & Linking 

23 

Parameter Length = 4 

24-27 

Accumulated Transitions to ldle_B 

28-29 

Parameter Code 0004h 

30 

DU Obsolete TSD ETC TMC TMC FMT & Linking FMT & Linking 

31 

Parameter Length = 4 

32-35 

Accumulated Transitions to ldle_C 

36-37 

Parameter Code 0008h 

38 

DU Obsolete TSD ETC TMC TMC FMT & Linking FMT & Linking 

39 

Parameter Length = 4 

40-43 

Accumulated Transitions to Standby_Z 

44-45 

Parameter Code 0009h 

46 

DU Obsolete TSD ETC TMC TMC FMT & Linking FMT & Linking 

47 

Parameter Length = 4 

48-51 

Accumulated Transitions to Standby_Y 
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8.8.15 Log Sense Page 2F 


This page contains SMART Status and Temperature Reading. 
Table 120 Log Sense Page 2F 


Byte 

Bit 

7 6 

5 4 3 2 1 0 

0 

Reserved 

Page code = 2Fh 

1 

Reserved 

2-3 

Page Length = 8 

4-5 

Parameter Code = OOOOh 

6 

DU = 0 DS = 0 TSD = 0 ETC = 0 TMC = 0 F&L = 11b 

7 

Parameter Length = 04h 

8 

SMART Sense Code Byte 

9 

SMART Sense Qualifier 

10 

Most Recent Temperature Reading 

11 

Vendor HDA Temperature Trip Point 
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8.8.16 Log Sense Page 30 


This page contains Performance Counters. 
Table 121 Log Sense Page 30 


Byte 

Bit 

7 6 

5 | 4 | 3 | 2 | 1 | 0 

0 

Reserved 

Page code = 30h 

1 

Reserved 

2-3 

Page Length = 0030h 

4-5 

Parameter Code = OOOOh 

6 

DU = 0 DS = 0 TSD=0 ETC=0 TMC = 0 F&L = 00b 

7 

Parameter Length = 2Ch 

8-9 

Zero Seeks 

10-11 

Seeks > = to 2/3 

12-13 

Seeks > = 1/3 and < 2/3 

14-15 

Seeks > = 1/6 and < 1/3 

16-17 

Seeks > = 1/12 and < 1/6 

18-19 

Seeks > 0 and <1/12 

20-23 

Reserved = 0 

24-25 

Overrun Counter 

26-27 

Under run Counter 

28-31 

Device Cache Full Read Hits 

32-35 

Device Cache Partial Read Hits 

36-39 

Device Cache Write Hits 

40-43 

Device Cache Fast Writes 

44-47 

Device Cache Read Misses 

48-51 

Reserved = 0 


Page 30h returns performance counter information. This includes seek counters and buffer overrun/under run 
counters. 

The appropriate seek counter is incremented once during execution of Pre-Fetch, Read, Verify, Write, Write and 
Verify, Write Same, and Seek commands. 

Buffer Overrun conditions are detected during Read commands. 

Buffer Under run conditions are detected during Verify with ByteChk=1, Write, Write and Verify, and Write Same 
commands. 

Only one seek counter is incremented for each of these commands and the counter is incremented only once per 
command. The length of the initial seek that is required to access the first Logical Block specified for the SCSI 
command determines which seek counter is incremented. The Zero Seek counter is incremented if a seek is not 
required or if only a head switch is required to access the first Logical Block. After the initial seek, no further counter 
incrementing is performed for that command. 

Note: The length of a seek as reported in page 30 may differ from expected results. The reason for this is that the 
drive executes Idle Time Functions between operations of the drive. The seek operations that occur in Idle 
Time Functions are not directly entered into page 30 seek counters but they change the length of the following 
seek. This is because after the Idle Time Function is completed, the heads will not necessarily be in the same 
position as they were at the completion of the previous command. 

A buffer overrun or under run condition occurs when the Initiator does not transfer data to or from the Target data 
buffer fast enough to keep up with reading or writing the media. The buffer overrun counter is incremented during 
operations that require a Data In phase when a buffer full condition prevents the continued transfer of data from the 
media to the data buffer. The buffer under run counter is incremented during operations that require a Data Out phase 
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when a buffer empty condition prevents the start or continuation of a data transfer from the data buffer to the media 
(or a data transfer from the media for a Verify command with BytChk=1). 

Buffer Overrun conditions are detected during the following SCSI commands: 

• READ (6) 

• READ (10) 

Buffer Under Run conditions are detected during the following SCSI commands: 

• VERIFY WITH BytChk=1 

• VERIFY (16) WITH BytChk=1 

• WRITE (6) 

• WRITE (10) 

• WRITE AND VERIFY 

• WRITE AND VERIFY (16) 

• WRITE SAME 

• WRITE SAME (16) 

• ZERO SEEKS 

The number of times no seek was required. The operation may have resulted in a head switch. 

• SEEKS >=2/3 DISK 

The number of seeks equal to or greater than 2/3 of the disk. 

• SEEKS >=1/3 AND < 2/3 DISK 

The number of seeks equal to or greater than 1/3 and less than 2/3 of the disk. 

• SEEKS >=1/6 AND <1/3 DISK 

The number of seeks equal to or greater than 1/6 and less than 1/3 of the disk. 

• SEEKS >=1/12 AND <1/6 DISK 

The number of seeks equal to or greater than 1/12 and less than 1/6 of the disk. 

• SEEKS >0 AND <1/12 DISK 

The number of seeks less than 1/12 of the disk. 

• OVERRUN COUNTER 

The number of times that data was available to be transferred from the media but the device buffer still contained 
data that had not been retrieved by the Initiator. Consequently, the disk had to take additional revolutions until 
the buffer was available to accept data. 

• UNDER RUN COUNTER 

The number of times that the drive was ready to transfer data to its disk (on a write), but its buffer was empty 
(i.e., had not been filled by the Initiator), thus the disk was forced to take extra revolutions. 

• DEVICE CACHE FULL READ HITS 

The number of times that all of the data requested by the read operation was obtained from the device read or 
write cache. 

• DEVICE CACHE PARTIAL READ HITS 

The number of times that a portion, but not all, of the data requested by the read operation was obtained from 
the device read or write cache. A physical operation to the device media was required to obtain the remaining 
data. 

• DEVICE CACHE WRITE HITS 

The number of times that the data associated with a write operation replaces, or is combined with, existing data 
in the device write cache, thereby eliminating a write operation. 

• DEVICE CACHE FAST WRITES 

The number of times that space was available in the device write cache for the data associated with a write 
operation and a response was returned immediately. 

• DEVICE CACHE READ MISSES 

The number of times that none of the data requested by the read operation was obtained from the read cache. 

The statistics reported by this page are lost on a self-initiated reset or when the Drive is powered off.Even though the 
DS field equals zero, the parameters on this page are not savable. 
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8.8.17 Log Sense Page 37 

This page contains a series of miscellaneous data counters including information about predictive failure analysis 
occurrences. 

Table 122 Log Sense Page 37 


Byte 

Bit 

7 6 

5 | 4 | 3 | 2 | 1 | 0 

0 

Reserved 

Page code = 37h 

1 

Reserved 

2-3 

Page Length = 0030h (48) 

4-5 

Parameter Code = OOOOh 

6 

DU=0 DS=0 TSD=0 ETC=0 TMC = 0 F&L = 00b 

7 

Parameter Length = 2Ch 

8-11 

(MSB) 

Power on Hours (hours only) 

(LSB) 

12-19 

(MSB) 

Total Bytes Read 

(LSB) 

20-27 

(MSB) 

Total Bytes Written 

(LSB) 

28 

Max Drive Temp (degrees Celsius) 

29-30 

(MSB) 

GList Size 

(LSB) 

31 

Number of Information Exceptions 

32 

MED EXC HDW EXC Reserved = 0 

33-40 

Total Read Commands 

41 -48 

Total Write Commands 

49 

Reserved = 0 

50-51 

Flash Correction Count 


The Power on Hours field specifies the total time the drive has been powered on in hours only. 

The Max. Drive Temperature field specifies the maximum temperature, in degrees Celsius, the drive has ever 
reached. 

The Glist Size field gives the total number of LBAs that have been reassigned on the drive. 

The Number of Information Exceptions field gives the number of Information Exceptions during the life of the drive 
and not the number of Information Exceptions that have been reported. The number of reported Information 
Exceptions may be less due to the settings of Mode Page 0x1 C.NOTE: This field does not include occurrences of 
any Information Exception Warnings. 

If set, the Media Exception and Hardware Exception bits indicate that an Information Exception has occurred during 
the life of the drive. These flags are set during an Information Exception that mayor may not coincide with the reporting 
of an Information Exceptions as mentioned above. 

Total Read Commands counter is incremented for each Read (6) and Read (10) command received. 

Total Write Commands counter is incremented for each Write (6), Write (10), Write Verify and Write Verify (16) 
command received. 

Flash Correction Count is incremented each time ECC correction is applied to data stored in Flash ROM. 
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8.9 MODE SELECT (15) 


Table 123 Mode Select (15) 


Byte 

Bit 

765 

4 3 2 1 

° 

0 

Command Code = 15h 

1 

Reserved = 0 

PF=1 Reserved = 0 

SP 

2 

3 

Reserved = 0 

4 

Parameter List Length 

5 

VU = 0 

Reserved = 0 FLAG 

LINK 


The MODE SELECT (15) command provides a means for the Initiator to specify LUN or device parameters to the 
Target. It also allows an Initiator to specify options the Target uses in error recovery, caching, and formatting. 

There is a single set of Mode Page parameters shared by all Initiators. 

• PF A PF (Page Format) bit value of one indicates that the data sent by the Initiator after the Mode Select Header 
and the Block Descriptor, if any, complies to the Page Format. The Target ignores this field since it only accepts 
mode parameters in the Page Format. 

• SP Save Pages. This indicates 


Table 124 Save Pages 


0 

The drive shall not save the pages sent during the Data Out phase but will use them for all following 
commands until the power is removed, a reset is received, or a new MODE SELECT command is received. 

1 

The drive will save the data in the reserved area of the disk. It will be used for all the following commands 
until another MODE SELECT command is issued. This information is maintained over a power cycle or reset 
of the drive. 


• Parameter List Length This specifies the number of bytes to be sent from the Initiator. A parameter list length 
of zero suppresses data transfer and is not considered an error. 


The MODE SELECT parameter list contains a 4-byte header followed by zero or one block descriptor followed by 
zero or more pages. The pages that are valid with this command are defined in the addendum under the heading 
Mode Select Data, as they vary with the drive model. 

Application Note 

The Initiator should issue a MODE SENSE command requesting all Changeable values (see PCF field in byte two of 
the CDB in) prior to issuing a MODE SELECT command. This is necessary to find out which pages are implemented 
by the drive and the length of those pages. In the Pages of the MODE SENSE command the drive will return the 
number of bytes supported for each Page. The Page Length set by the Initiator in the MODE SELECT command 
must be the same value as returned by the drive in MODE SENSE Page Length. If not, the drive will return Check 
Condition status with sense key of Illegal Request. 

Note: If an Initiator sends a MODE SELECT command that changes any parameters that apply to other Initiators, 

the drive shall generate a unit attention condition for all Initiators except for the one that issued the MODE SELECT 
command. The drive shall set the additional sense code to Parameters Changed (2Ah). 
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8.10 MODE SELECT (55) 


Table 125 Mode Select (55) 


Byte 

Bit 

7 6 5 4 3 210 

0 

Command Code = 55h 

1 

Reserved = 0 PF=1 Reserved = 0 SP 

2-6 

Reserved = 0 

7-8 

(MSB) 

Parameter List Length 

(LSB) 

9 

VU = 0 Reserved = 0 FLAG LINK 


The MODE SELECT (55) command provides a means for the Initiator to specify LUN or device parameters to the 
Target. 

See the MODE SELECT (15) command for a description of the fields in this command. 
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8.11 MODE SENSE (1A) 


Table 126 Mode Sense (1A) 


Byte 

Bit 

7 6 

5 4 3 2 

10 

0 

Command Code = 1 Ah 

1 

Reserved=0 

RSVD DBD 

Reserved = 0 

2 

PCF 

Page Code 


3 

Subpage Code 

4 

Allocation Length 

5 

VU = 0 

Reserved = 0 

FLAG LINK 


The MODE SENSE (1 A) command provides a means for the drive to report various device parameters to the Initiator. 
It is the complement to the MODE SELECT command. 

If the DBD (Disable Block Descriptor) bit is zero, the Target will return a Block Descriptor. If the DBD bit is set to 1, 
the Target will not return a Block Descriptor. 

Allocation Length indicates the maximum number of bytes that the Initiator has set aside for the DATA IN phase. A 
value of zero is not considered an error. If the allocation length is smaller than the amount available, that portion of 
the data up to the allocation length will be sent. This may result in only a portion of a multi-byte field being sent. 

Page Control Field: PCF (Page Control Field) defines the type of Page Parameter values to be returned. 

PCF Meaning 

0 0 Report current values. The drive returns the current values under which the logical unit is presently 
configured for the page code specified. The current values returned are 

1. Initially following power-up but before the media is accessed, the default values become current. Once 
the media can be accessed, the saved values are read from the Reserved Area and become current. 

2. The parameters set in the last successful MODE SELECT command. 

3. The saved values if a MODE SELECT command has not been executed since the last power-on, hard 
RESET condition, or TARGET RESET message. 

Following the completion of start-up, execution of the MODE SELECT command can modify the current 
values. 

Note: Those parameters associated with format are not considered current and are not saved until the 
successful completion of a FORMAT UNIT command. 

In addition, the current values take on the saved values after a reset if the parameters were saved. If the 
Page Code is 3Fh, then all pages implemented by the Target are returned to the Initiator with fields and bit 
values set to current values. 

If the Page Code is not 3Fh, the page defined by the Page Code, if supported by the Target, is returned with 
fields and bits set to current values. 

Note: The drive will not process the MODE SELECT command until the completion of spin-up. Therefore, 
the Initiator cannot modify the current values prior to the saved values being read in. 

0 1 Report changeable value. The drive returns the changeable values for the page code specified. The 
page requested is returned containing information that indicates which fields are changeable. All bits of 
parameters that are changeable shall be set to one. Parameters that are defined by the drive shall be set to 
zero. If any part of a field is changeable, all bits in that field shall be set to one. 

Note: For a value field such as the buffer ratios of page 2 the bit field will not indicate the range of supported 
values but rather that the field is supported. 
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1 0 Report default value. The drive returns the default values for the page code specified. The parameters 
not supported by the drive are set to zero. 

1 1 Report saved value. The drive returns the saved value for the page code specified. 

Saved values are one of the following: 

- the values saved as a result of MODE SELECT command 

- identical to the default values 

- zero when the parameters are not supported 

The Page Length byte value of each page returned by the drive indicates up to which fields are supported 
on that page. 

Page Code: This field specifies which page or pages to return. Page code usage is defined in the figure below. 
Table 127 Page Code Usage 


Page Code 

Description 

OOh- ICh 

3Fh 

Return specific page, if supported. 

Return all supported pages. 


If a Page Code of 3Fh is used, MODE SENSE returns the pages in ascending order with one exception. Page 0 is 
always returned last in response to a MODE SENSE command. 

If an unsupported page is selected, the command is terminated with a CHECKCONDITION status and available 
sense of ILLEGAL REQUEST/INVALID FIELD IN CDB. 

Subpage Code: This field specifies the subpage to return, and may be set to a specific page, or to FFh for all 
supported subpages. 
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8.11.1 Mode Parameter List 

The mode parameter list contains a header followed by zero or one block descriptors followed by zero or more variable 
length pages. 

8.11.1.1 Header 

The header used for the 6-byte CDB is defined below. 

Table 128 Mode parameter header (6) 


Byte 

Bit 

7 

6 5 4 3 | 

2 _1_ 1 _1 

_ 0 _1 

0 

Mode Data Length 

1 

Medium Type = 0 

2 

WP=0 

Reserved=0 DPOFUA = 1 

Reserved = 0 

1 

3 

Block Descriptor Length (=0 or 8) 


The header used for the 10-byte CDB is defined below. 
Table 129 Mode parameter header (10) 


Byte 

Bit 

7 6 5 4 3 210 

0-1 

(MSB) 

Mode Data Length 

(LSB) 

2 

Medium Type = 0 

3 

WP=0 Reserved=0 DPOFUA =1 Reserved = 0 

4 

Reserved = 0 Long LBA 

5 

Reserved = 0 

6-7 

(MSB) 

Block Descriptor Length 

(LSB) 


• Mode Data Length. When using the MODE SENSE command, the mode data length field specifies the length 
in bytes of the following data that is available to be transferred. The mode data length does not include the length 
byte itself. When using the MODE SELECT command, this field is reserved. 

• Medium Type field is always set to zero in the drive (Default Medium Type). 

• WP. When used with the MODE SELECT command, the Write Protect (WP) bit is reserved. 

When used with the MODE SENSE command, a Write Protect (WP) bit of zero indicates that the medium is write 
enabled. 

• DPOFUA bit value of 1 indicates that the Target supports the FUA and DPO bits in the Read and Write 
Commands. 

• LONGLBA bit value of 0 indicates that any following Block Descriptor uses the Short LBA Block Descriptor 
format. A LONGLBA bit value of 1 indicates that any following Block Descriptor uses the Long LBA Block 
Descriptor format 

• Block Descriptor Length specifies the length in bytes of the block descriptor. Values of 0, 8, and 16 are 
supported by the Target, respectively corresponding to an absent Block Descriptor, a single Short LBA Block 
Descriptor, and a single Long LBA Block Descriptor. 

Note: DPOFUA is ignored during Mode Select command processing although the SCSI Standard states that it is 
reserved during Mode Select. Ignoring it allows the Mode Sense Parameter List for the byte containing this bit to be 
re-used as a Mode Select Parameter List. 
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8.11.1.2 Block Descriptors 


Table 130 Short LB A Mode Parameter Block Descriptor 


Byte 

Bit 

7 6 5 4 3 21 0 

0-3 

(MSB) 

Number of Blocks 

(LSB) 

4 

Reserved = 0 

5-7 

(MSB) 

Block Length 

(LSB) 


Table 131 Long LB A Mode Parameter Block Descriptor 


Byte 

Bit 

7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 

0-7 

(MSB) 

Number of Blocks 

(LSB) 

8-11 

Reserved = 0 

12-15 

(MSB) 

Block Length 

(LSB) 


The Block descriptor provides formatting information about the Number of Blocks (user addressable) to format at the 
specified Block Length. 

• Number of Blocks 

When used with the MODE SELECT command, the Number of Blocks field must be 

- Zero to indicate not to change available blocks 

- OxFFFFFFFF (Short LBA) or OxFFFFFFFFFFFFFFFF (Long LBA) to indicate all available blocks 

- The exact number of blocks in the data area of the drive, which can be obtained with the MODE SENSE 

- The number of blocks less than exact one, in order to CLIP the number of blocks 
Any other value is invalid and causes the command to fail with Check Condition status. 

When returned by the MODE SENSE command, the field contains the exact number of blocks. 

• Block Length 

The Block Length field reflects the number of bytes of user data per sector (not including any protection 
information). When used with the MODE SELECT command, the Block Length field must contain a value from 
512 to 528 (8 bytes step) or zero. Otherwise the drive will terminate the command with Check Condition status. 
A FORMAT UNIT command is required to cause these parameters to become current only if the block length 
parameter is different from the current block length. 
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8.11.1.3 Page Descriptor 


Table 132 Mode Parameter Page Format 


Byte 0 

PS SPF Page Code 

Byte 1 

Page Length 

Byte 2-n 

Mode Parameters 


Each mode page contains a page code, a page length, and a set of mode parameters. 

When using the MODE SENSE command, a Parameter Savable (PS) bit of one indicates that the mode page can be 
saved by the drive in the reserved area of the drive. A PS bit of zero indicates that the supported parameters cannot 
be saved. When using the MODE SELECT command, the PS bit is reserved (zero). 

SPF (Sub-Page Format) is set to zero to indicate the short page format is used. The bit is set to one to indicate the 
long format is used, supporting sub-pages. The drive supports the following mode page codes: 

Table 133 Mode Parameter Page Format 


Page 

Description 

PS 

00 

Vendor Unique Parameters 

1 

01 

Read-Write Error Recovery Parameters 

1 

02 

Disconnect/Reconnect Control Parameters 

1 

03 

Format Device Parameters 

0 

04 

Rigid Disk Geometry Parameters 

0 

07 

Verify Error Recovery Parameters 

1 

08 

Caching Parameters 

1 

0A 

Control Mode Page 

1 

OC 

Notch Parameters 

1 

19 

Port Control Page 

1 

1A 

Power Control Parameters 

1 

1C 

Informational Exceptions Control 

1 


The page length field specifies the length in bytes of the mode parameters that follow. If the Initiator does not set this 
value to the value that is returned for the page by the MODE SENSE command, the drive will terminate the command 
with Check Condition status. 
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8.11.2 Mode Page 00 (Vendor Unique Parameters) 


Table 134 Vendor Unique Parameters - Page 00 


Byte 

Bit 

Default 

7 

6 

5 4 3 2 1 0 

0 

PS 

0 

Page Code = OOh 

80h 

1 

Page Length = OEh 

OEh 

2 

Reserved MRG Reserved 

Ignored 

OOh 

3 

Reserved VGMDE Reserved RRNDE 

Reserved 

OOh 

4 

Reserved 

OOh 

5 

Reserved FDD 

Reserved CAEN Ignored 

02h 

6 

IGRA AVERP Reserved 

OCT (high nibble) 

OOh 

7 

Overall Command Timer (low byte) 

OOh 

8 

Reserved 

OOh 

9 

Temperature Threshold 

OOh 

10 

Command Aging Limit (Hi byte) 

OOh 

11 

Command Aging Limit (Low byte) 

30h 

12 

Read Reporting Threshold 

16h 

13 

Write Reporting Threshold 

14h 

14 

DRRT 

Ignored 

FFMT 

Ignored 

OOh 

15 

Ignored 

Reserved FCERT Ignored 

Reserved 

Ignored Reserved 

OOh 


Fields marked in the table as 'Ignored' are not used or checked by the drive. They will be initialized to zero but can 
be set as desired for compatibility with older drives. 

• MRG (Merge Glist into Plist) bit is set to 1 for merging the Glist entries into the Plist during FORMAT UNIT 
command. 

• VGMDE (Veggie Mode) bit set to 1 will cause the drive to execute random self-seeks. To enable this mode, the 
initiator must perform the mode select to set the bit while the drive is spinning, then Stop Unit, then Start Unit. 
VGMDE set to 0 disables the self-seeks (normal operation). 

• RRNDE (Report Recovered Non Data Errors) bit controls the reporting of recovered Non Data Errors when the 
PER bit is set. If RRNDE is set, recovered Non Data Errors are reported. If the RRNDE bit is not set, then 
recovered Non Data Errors are not reported. 

• FDD(Format Degraded Disable) controls the reporting of Format Degraded sense data for Test Unit Ready 
commands when the drive is in a format degraded state. When the FDD bit is one, Format Degraded sense data 
will not be reported for a Test Unit Ready command. When the FDD bit is zero, Format Degraded sense data 
will be reported for Test Unit Ready commands when the drive is in a format degraded state. This bit does not 
affect the reporting of Format Degraded conditions for any media access commands. 

• CAEN (Command Aging Enable) When set this bit causes the Command Age Limit timer to be used to avoid 
commands waiting in the command queue for an indefinite period. When commands have been in the queue for 
a period of time greater than the timer limit they will be reordered to be executed on a first come first served 
basis. When this bit is reset, commands are always executed based on the queue reordering rules. 

• IGRA (Ignore Reassigned LBA) bit works in conjunction with the RC bit (Mode Page 01 h, byte 2, bit 4).The main 
purpose of this bit is to avoid undesirable read processing time delays due to reassigned LBA processing for 
continuous data availability requirements such as Audio Visual applications. If IGRA is set to one and RC is set 
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to one, out-of-line reassigned LBAs will not be processed. If IGRA is set to one and RC is set to zero, or if IGRA 
is set to zero, reassigned LBAs will be processed normally. 

AVERP (AV ERP Mode) bit is set to one in order to specify maximum retry counts during Read DRP. When 
AVERP bit is set to one, the maximum retry counts for read operations is specified by Read Retry Count (Mode 
Page 1 Byte 3). AVERP bit is set to zero to specify that the drive shall process read DRP up to the default 
maximum retry count when Read Retry Count is set to a non-zero value. 

OCT(Overall Command Timer) controls the maximum command execution time, from receipt by the drive until 
status is returned. If the command is unable to complete in the specified amount of time, it will be aborted with 
Check Condition status, Aborted Command sense key. The Overall Command Timer does not alter the behavior 
of the Command Aging Limit or Recovery Time Limit. Each unit of this timer is 50 milliseconds. Setting the value 
to zero disable the feature. 

Temperature Threshold Temperature Threshold specifies the threshold value in degrees Celsius for the 
thermal sensor Information Exception Warning; the reporting of which is controlled by Mode Page 0x1 C. A value 
of 0 selects the default value (85 degrees Celsius). 

Command Aging Limit This value controls the maximum time a command should wait in the command queue 
when the CAEN bit is set. Each unit of this timer is 50ms. 

Read Reporting Threshold specifies the recovery step that must be exceeded to report recovered data errors 
during read operations when PER=1 .For example, if the Read Reporting Threshold is set to 22, recovered read 
errors will be reported starting at recovery step 23 

Write Reporting Threshold specifies the recovery step that must be exceeded to report recovered data errors 
during write operations when PER=1 .For example, if the Write Reporting Threshold is set to 20, recovered write 
errors will be reported starting at recovery step 21. 

DRRT (Disable Restore Reassign Target) bit which disables the reading and restoration of the target LBA during 
a Reassign Blocks command is not supported as a Reassign Block command is not supported. 

FFMT (Fast Format Enable) bit allows the formatting of the drive without any writes to the customer media. All 
format operations are allowed including changing block sizes and manipulating defects. The drive will operate 
normally after a fast format with the following caveat: since no data is written to any customer data blocks as a 
result of a Fast Format operation, there is a possibility that a read attempt to any particular block (without having 
previously written to that block) will result in an unrecoverable data error. This will most likely happen if the block 
size is changed as every LBA will contain data of an incorrect length and apparently an incorrect starting point. 
It is also possible to generate an uncorrectable data error without changing block sizes if the defect list is 
shortened and previously bad blocks become visible in the customer address space. Of course ALL DATA ON 
THE DRIVE WILL BE LOST as the result of any format operation and so any attempt to read blocks which have 
not been written to will result in unpredictable behavior. 

When FFMT bit is set to zero, initializes the Indirection Table, to Zero Fill the Conventional Zone area, but the 
others will not write to the disk media. 

FCERT (Format Certification) bit determines whether the certification step will be performed during a Format 
Unit command. FCERT bit set to 0 disables certification. FCERT bit set to 1 enables the certification step. 
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8.11.3 Mode Page 01 (Read/Write Error Recovery Parameters) 


Table 135 Mode Page 01 (Vendor Unique Parameters) 


Byte 

Bit 

Default 

7 

6 

5 4 3 2 1 0 

0 

PS 

0 

Page Code = 01 h 

81 h 

1 

Page Length = OAh 

OAh 

2 

AWRE ARRE TB RC EER=0 PER DTE DCR=0 

COh 

3 

Read Retry Count 

01 h 

4 

Obsolete = 0 

OOh 

5 

Obsolete = 0 

OOh 

6 

Obsolete = 0 

OOh 

7 

Reserved 

OOh 

8 

Write Retry Count 

01 h 

9 

Reserved 

OOh 

10-11 

(MSB) 

Recovery Time Limit 

(LSB) 

OOh 


The Read-Write recovery parameters that will be used during any command that performs a read or write operation 
to the medium are as follows: 

• AWRE Automatic Write Reallocation Enabled bit, set to zero indicates that the drive shall not perform automatic 
reallocation of defective data blocks during write operations. An AWRE bit set to one indicates that the drive 
shall perform automatic reallocation of defective data blocks during write operations. 

• ARRE Automatic Read Reallocation Enabled bit, set to zero indicates that the drive shall not perform automatic 
reallocation of defective data blocks during read operations. ARRE bit set to one indicates that the drive shall 
perform automatic reallocation of defective data blocks during read operations. 

• TB Transfer Block bit, set to one indicates that a data block that is not recovered within the recovery limits 
specified shall be transferred to the Initiator before Check Condition status is returned. A TB bit set to zero 
indicates that such a data block shall not be transferred to the Initiator. Data blocks that can be recovered within 
the recovery limits are always transferred regardless of the value of the bit. 

• RC Read Continuous bit, set to one requests the Target to transfer the entire requested length of data without 
adding delays that would increase or ensure data integrity. This implies that the Target may send erroneous 
data. This bit has priority over all other error control bits (PER, DTE, DCR, TB). RC set to zero indicates normal 
interpretation of PER, DTE, DCR, and TB values. The RC bit setting is used by the Target when reporting errors 
associated with the transfer of the Initiator's data for the Read commands interpretation of PER, DTE, DCR, and 
TB values. The RC bit applies only to READ commands. 

Note: The Target implementation of the RC option is to disable error detection of the data fields but continue normal error 
detection and recovery for errors occurring in the servo field. If a servo field failure occurs, normal DRP could result in 
considerable recovery action, including proceeding through all levels of DRP. 

• EER an Enable Early Recovery bit, must be set to zero, indicating that the drive shall use an error recovery 
procedure that minimizes the risk of misdetection or miscorrection during the data transfer. Data shall not be 
fabricated. 

• PER Post Error bit, is set to one to indicate that the drive reports recovered errors. 
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• DTE (Data Terminate on Error) bit set to one specifies that data transfer will be halted when the first recovered 
error is encountered. PER must be set to one when DTE is set to one. DTE set to zero will cause data transfer 
to continue when recovered errors are encountered. 

• DCR - Reserved 

• Read Retry Count sets a limit on the amount of DRP passes in which the Target attempts to recover read errors. 
A value of zero disables all data recovery procedures. When AVERP bit (Mode Page 0 Byte 6 Bit 6) is zero, a 
value of non-zero in Read Retry Count enables all steps of DRP. When AVERP bit is one, the number in Read 
Retry Count sets the maximum retry count of DRP. 

• Write Retry Count sets a limit on the amount of DRP passes in which the Target attempts to recover write errors. 
A value of zero disables all data recovery procedures. 

• Recovery Time Limit indicates the period in 1 millisecond increments for the maximum recovery time of a single 
LBA. The value must be from 40 ms to 65535 ms (65.5 seconds).The granularity of the timer is 50ms. If an LBA 
is not able to be recovered within the limit, a Check Condition will be returned. The Recovery Time Limit will not 
be applied to Writes when WCE=1. A value of zero disables the timer. 

The following summarizes valid modes of operation. If an illegal mode is set, the MODE SELECT command will 
complete successfully but the action of the drive when an error occurs is undefined. 


Table 136 PERDTEDCRTB (1/3) 


PERDTEDCRTB 

DESCRIPTION 

0000 

Retries and Error Correction are attempted. Recovered or corrected data (if any) or both 
are transferred with no Check Condition status at the end of the transfer. 

no err 

The transfer length is exhausted. 

soft err 

The transfer length is exhausted. Transferred data includes blocks containing 
recovered errors. 

hard err 

Data transfer stops when an unrecoverable error is encountered. The 
unrecoverable block is not transferred to the Initiator. The drive then creates 
the Check Condition status with the appropriate sense key. 

0001 

Retries and Error Correction are attempted. Recovered or corrected data (if any) or both are 
transferred with no Check Condition status at the end of the transfer. 

no err 

The transfer length is exhausted. 

soft err 

The transfer length is exhausted. Transferred data includes blocks containing 
recovered errors. 

hard err 

Data transfer stops when an unrecoverable error is encountered. The 
unrecoverable block is transferred to the Initiator. The drive then creates the 
Check Condition status with the appropriate sense key. 

00 10 

Retries are attempted but no error correction (LDPC) is applied. Recovered data (if any) are 
transferred with no Check Condition status at the end of the transfer. 

no err 

The transfer length is exhausted. 

soft err 

The transfer length is exhausted. Transferred data includes blocks containing 
recovered errors. 

hard err 

Data transfer stops when an unrecoverable error is encountered. The 
unrecoverable block is not transferred to the Initiator. The drive then creates 
the Check Condition status with the appropriate sense key. 

00 11 

Retries are attempted but no error correction (LDPC) is applied. Recovered data (if any) are 
transferred with no Check Condition status at the end of the transfer. 

no err 

The transfer length is exhausted. 

soft err 

The transfer length is exhausted. Transferred data includes blocks containing 
recovered errors. 

hard err 

Data transfer stops when an unrecoverable error is encountered. The 
unrecoverable block is transferred to the Initiator. The drive then creates the 
Check Condition status with the appropriate sense key. 
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Table 137 PERDTEDCRTB (2/3) 


PERDTEDCRTB 

DESCRIPTION 

0100 

Illegal Request-DTE must be zero when PER is zero. 

010 1 

Illegal Request-DTE must be zero when PER is zero. 

0110 

Illegal Request-DTE must be zero when PER is zero. 

0111 

Illegal Request-DTE must be zero when PER is zero. 

1000 

The highest level error is reported at the end of transfer. Retries and error correction are 
attempted. Recovered or corrected data (if any) or both are transferred with Check Condition 
status and Recovered Error sense key set at the end of the transfer. 

no err 

The transfer length is exhausted. 

soft err 

The transfer length is exhausted. Transferred data includes blocks containing 
recovered errors. The information byte in the sense data will contain the LBAof 
the last recovered error. 

hard err 

Data transfer stops when an unrecoverable error is encountered. The 
unrecoverable block is not transferred to the Initiator. The drive then creates the 
Check Condition status with the appropriate sense key. 

100 1 

The highest level error is reported at the end of transfer. Retries and error correction are 
attempted. Recovered or corrected data (if any) or both are transferred with Check Condition 
status and Recovered Error sense key set at the end of the transfer. 

no err 

The transfer length is exhausted. 

soft err 

The transfer length is exhausted. Transferred data includes blocks containing 
recovered errors. The information byte in the sense data will contain the LBAof 
the last recovered error. 

hard err 

Data transfer stops when an unrecoverable error is encountered. The 
unrecoverable block is not transferred to the Initiator. The drive then creates the 
Check Condition status with the appropriate sense key. 

1010 

The highest level error is reported at the end of transfer. Retries are attempted but LDPC is 
not applied. Recovered or corrected data (if any) or both are transferred with Check Condition 
status and Recovered Error sense key set at the end of the transfer. 

no err 

The transfer length is exhausted. 

soft err 

The transfer length is exhausted. Transferred data includes blocks containing 
recovered errors. The information byte in the sense data will contain the LBA of 
the last recovered error. 

hard err 

Data transfer stops when an unrecoverable error is encountered. The 
unrecoverable block is not transferred to the Initiator. The drive then creates the 
Check Condition status with the appropriate sense key. 

10 11 

The highest level error is reported at the end of transfer. Retries and error correction are 
attempted. Recovered or corrected data (if any) or both are transferred with Check Condition 
status and Recovered Error sense key set at the end of the transfer. 

no err 

The transfer length is exhausted. 

soft err 

The transfer stops on the first soft error detected. The information in the sense 
data shall contain the LBA of the block in error. 

hard err 

Data transfer stops on the unrecoverable error. The unrecoverable error block is 
not returned to the Initiator. The drive then creates the Check Condition status with 
the appropriate sense key. 
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Table 138 PERDTEDCRTB (3/3) 


PERDTEDCRTB 

DESCRIPTION 

1100 

The highest level error is reported at the end of transfer. Retries and error correction are 
attempted. Recovered or corrected data (if any) or both are transferred with Check Condition 
status and Recovered Error sense key set at the end of the transfer. 

no err 

The transfer length is exhausted. 

soft err 

The transfer stops on the first soft error detected. The information in the sense 
data shall contain the LBA of the block in error. 

hard err 

Data transfer stops on the unrecoverable error. The unrecoverable error block is 
not returned to the Initiator. The drive then creates the Check Condition status with 
the appropriate sense key. 

10 11 

The highest level error is reported at the end of transfer. Retries and error correction are 
attempted. Recovered or corrected data (if any) or both are transferred with Check Condition 
status and Recovered Error sense key set at the end of the transfer. 

no err 

The transfer length is exhausted. 

soft err 

The transfer stops on the first soft error detected. The information in the sense 
data shall contain the LBA of the block in error. 

hard err 

Data transfer stops on the unrecoverable error. The unrecoverable error block is 
returned to the Initiator. The drive then creates the Check Condition status with 
the appropriate sense key. 

1110 

The highest level error is reported at the end of transfer. Retries are attempted but LDPC is 
not applied. Recovered data are transferred with Check Condition status and Recovered 
Error sense key set at the end of the transfer. 

no err 

The transfer length is exhausted. 

soft err 

The transfer stops on the first soft error detected. The recovered error block is 
returned to the initiator. The information in the sense data shall contain the LBA of 
the block in error. 

hard err 

Data transfer stops on the unrecoverable error. The unrecoverable error block is 
not returned to the Initiator. The drive then creates the Check Condition status with 
the appropriate sense key. 

1111 

The highest level error is reported at the end of transfer. Retries are attempted but LDPC in 
not applied. Recovered or corrected data (if any) or both are transferred with Check Condition 
status and Recovered Error sense key set at the end of the transfer. 

no err 

The transfer length is exhausted. 

soft err 

The transfer stops on the first soft error detected. The information in the sense 
data shall contain the LBA of the block in error. 

hard err 

Data transfer stops on the unrecoverable error. The unrecoverable error block is 
returned to the Initiator. The drive then creates the Check Condition status with 
the appropriate sense key. 
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8.11.4 Mode Page 02 (Disconnect/Reconnect Parameters) 


Table 139 Mode Page 02 (Disconnect/Reconnect Parameters) 


Byte 

Bit 

Default 

7 

6 

5 | 4 | 3 | 2 | 1 | 0 

0 

PS 

0 

Page Code = 02h 

82h 

1 

Page Length = OEh 

OEh 

2 

Read Buffer Full Ratio 

OOh 

3 

Write Buffer Empty Ratio 

OOh 

4-5 

(MSB) 

Bus Inactivity Time Limit 

(LSB) 

OOh 

6-7 

Disconnect Time Limit = 0 

OOh 

8-9 

(MSB) 

Maximum Connect Time Limit 

(LSB) 

OOh 

10-11 

(MSB) 

Maximum Burst Size 

(LSB) 

OOh 

12-13 

Reserved = 0 

OOh 

14-15 

First Burst Size = 0 

OOh 


The disconnect/reconnect page provides the Initiator with the means to tune the performance of the SAS Link. 

The drive uses the disconnect/reconnect parameters to control when it attempts to regain control of the link during 
READ (operation code 08h and 28h) and WRITE (OAh, 2Ah and 2E). 

• Read Buffer Full Ratio is the numerator of a fraction whose denominator is 256. The fraction indicates how full 
the drive data buffer should be before attempting to re-arbitrate for the link. If the ratio is set to Oh, the target will 
calculate and use an optimal ratio based on the negotiated transfer rate. 

• Bus Inactivity Time Limit specifies the maximum time that the SAS target port is permitted to maintain a 
connection without transferring a frame to the initiator port, specified in 100 microsecond increments. When this 
value is exceeded, the target port will prepare to close the connection by transmitting DONE.A value of zero 
indicates that there is no bus inactivity time limit. 

• Disconnect Time Limit is not supported. 

• Write Buffer Empty Ratio is the numerator of a fraction whose denominator is 256. The fraction indicates how 
empty the drive data buffer should be before attempting to re-arbitrate for the link. If the ratio is set to Oh, the 
target will calculate and use an optimal ratio based on the negotiated transfer rate. Both the Read Buffer Full 
Ratio and the Write Buffer Empty Ratio pertain to the current active notch. For each active notch as defined in 
page OCh there are separate Read Buffer Full Ratios and Write Buffer Empty Ratios. When the active notch is 
set to zero, the values are applied in mode page OCh across all notches. 

• Maximum Connect Time Limit specifies the maximum amount of time the drive will keep a SAS connection 
open. The time is specified in 100 microsecond increments. The default value of zero indicates no time limit. A 
maximum value of FFFFh specifies a connection time limit of 6.55 seconds. When this time expires, the drive 
will prepare to close the connection. 

• Maximum Burst Size field indicates the maximum amount of data that the target port shall transfer during a 
single data transfer operation. This value is expressed in increments of 512 bytes. A value of zero specifies there 
is no limit on the amount of data transferred per data transfer operation. 

• First Burst Size is not supported. 
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8.11.5 Mode Page 03 (Format Device Parameters) 

Table 140 Mode Page 03 (Format Device Parameters) 


Byte 

| Bit 

Default 

7 

6 

5 | 4 | 3 | 2 | 1 | 0 

0 

PS 

0 

Page Code = 03h 

03h 

1 

Page Length = 16h 

16h 

2-3 

(MSB) 

Tracks per Zone 

(LSB) 

xxh 

xxh 

4-5 

(MSB) 

Alternate Sectors per Zone = 0 

(LSB) 

OOh 

OOh 

6-7 

(MSB) 

Alternate Tracks per Zone = 0 

(LSB) 

OOh 

OOh 

8-9 

(MSB) 

Alternate Tracks per Logical Unit = 0 

(LSB) 

OOh 

OOh 

10-11 

(MSB) 

Sectors Per Track 

(LSB) 

xxh 

xxh 

12-13 

(MSB) 

Data Bytes per Physical Sector 

(LSB) 

xxh 

xxh 

14-15 

(MSB) 

Interleave = 0001 h or OOOOh 

(LSB) 

OOh 

01 h 

16-17 

(MSB) 

Track Skew Factor 

(LSB) 

xxh 

xxh 

18-19 

(MSB) 

Cylinder Skew Factor 

(LSB) 

xxh 

xxh 

20 

SSEC | HSEC | RMB | SURF | RESERVED = 0 

40h 

21-23 

Reserved = 0 

OOh 


The format device page contains parameters that specify the medium format. This page contains no changeable 
parameters. 

• Tracks per Zone specifies the number of tracks within the zone. This field is a function of the active notch. 

• Sectors per Track specifies the number of physical sectors within each track. This field is a function of the active 
notch. 

• Data Bytes per Physical Sector specifies the number of user data bytes per physical sector. The value depends 
upon the current formatted Block Length. 

• Interleave value of 1 or 0 is valid. However, the drive will ignore this. 

• Track Skew Factor indicates the number of physical sectors between the last block of one track and the first 
block on the next sequential track of the same cylinder. This field is a function of the active notch. 

• Cylinder Skew Factor indicates the number of physical sectors between the last block of one cylinder and the 
first block on the next sequential cylinder. This field is a function of the active notch. 

• SSEC = Zero indicates that the drive does not support soft sector formatting. 

• HSEC = One indicates that the drive supports hard sector formatting. 
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• RMB = Zero indicates that the media does not support removable Fixed Disk. 

• SURF = Zero indicates that progressive addresses are assigned to all logical blocks in a cylinder prior to 
allocating addresses within the next cylinder. 

8.11.6 Mode Page 04 (Rigid Disk Drive Geometry Parameters) 


Table 141 Mode Page 04 (Rigid Disk Drive Geometry Parameters) 


Byte 

Bit 

Default 

7 

6 

5 4 3 2 1 0 

0 

PS 

0 

Page Code = 04h 

04h 

1 

Page Length = 16h 

16h 

2-4 

(MSB) 

Number of Cylinders 

(LSB) 

xxh 

xx h 

5 

Number of heads 

xxh 

6-8 

(MSB) 

Starting Cylinder - 
Write Pre compensation = 0 

(LSB) 

OOh 

OOh 

9-11 

(MSB) 

Starting Cylinder - 
Reduced Write Current = 0 
(LSB) 

OOh 

OOh 

12-13 

(MSB) 

Drive Step Rate = 0 (Not used) 

(LSB) 

OOh 

OOh 

14-16 

(MSB) 

Landing Zone Cylinder = 0 (Not used) 

(LSB) 

OOh 

OOh 

17 

RESERVED = 0 RPL = 0 

OOh 

18 

Rotational Offset = 0 (Not used) 

OOh 

19 

RESERVED = 0 

OOh 

20-21 

(MSB) 

Medium Rotation Rate in RPM 

(LSB) 

ICh 

20h 

22-23 

Reserved = 0 

OOh 


The rigid disk drive geometric page specifies various parameters for the drive. 

• RPL = 0, Indicates that the drive does not support spindle synchronization. 
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8.11.7 Mode Page 07 (Verify Error Recovery Parameters) 


Table 142 Mode Page 07 (Verify Error Recovery Parameters) 


Byte 

Bit 

Default 

7 

6 

5 4 3 2 1 0 

0 

PS 

0 

Page Code = 07h 

87h 

1 

Page Length = OAh 

OAh 

2 

Reserved = 0 EER=0 PER DTE DCR=0 

OOh 

3 

Verify Retry Count 

01 h 

4 

Obsolete =0 

OOh 

5-9 

Reserved = 0 

OOh 

10-11 

(MSB) 

Verify Recovery Time Limit 

(LSB) 

OOh 


The Verify recovery parameters are used by the Target when recovering from and reporting errors associated with 
the verification of the Initiator's Data for the following commands: 

• VERIFY 

• WRITE AND VERIFY - the verify portion of the command only. 

• EER This bit is 0 since the Target does not support early recovery. 

• PER (post error) bit is set to one to indicate that the drive reports recovered errors. The PER and DTE bit settings 
in mode page 7 override those of mode page 1 during VERIFY and the Verify portion of WRITE AND VERIFY 

• DTE (Data Terminate on Error) bit set to one specifies that data transfer will be halted when the first recovered 
error is encountered. PER must be set to one when DTE is set to one. DTE set to zero will cause data transfer 
to continue when recovered errors are encountered 

• DCR - Reserved 

• Verify Retry Count sets a limit on the amount of verify recovery procedure (VRP) passes the Target attempts 
when recovering verify errors. The Verify Retry Count of one causes the Target to attempt up to one VRP pass 
per command when a medium error occurs during a verify operation. Only values of Oh and 01 h are valid. The 
value of Oh disables all recovery. 

• Verify Recovery Time Limit indicates the period in 1 millisecond increments for the maximum recovery time of 
a single LBA during the verify operation. The value must be from 40 ms to 65535 ms (65.5 seconds). The 
granularity of the timer is 50ms. If an LBA is not able to be recovered within the limit, a Check Condition will be 
returned. 
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8.11.8 Mode Page 08 (Caching Parameters) 


Table 143 Page 08 (Caching Parameters) 


Byte 

Bit 

Default 

7 

6 

5 | 4 | 3 | 2 | 1 | 0 

0 

PS 

0 

Page Code = 08h 

88h 

1 

Page Length = 12h 

12h 

2 

1C ABPF CAP DISC 

SIZE WCE MF RCD 

04h 

3 

Demand Read Retention Priority 

Write Retention Priority 

OOh 

4-5 

(MSB) 

Disable Pre-fetch Transfer Length 

(LSB) 

FFh 

6-7 

(MSB) 

Minimum Pre-fetch 

(LSB) 

OOh 

8-9 

(MSB) 

Minimum Pre-fetch 

(LSB) 

FFh 

10-11 

Maximum Pre-fetch Ceiling 

FFh 

12 

FSW LBCSS DRA Reserved = 0 

OOh 

13 

Number of Cache Segments 

08h 

14-15 

(MSB) 

Cache Segment Size 

(LSB) 

OOh 

16 

Reserved = 0 

OOh 

17-19 

(MSB) 

Non Cache Segment Size 

(LSB) 

OOh 


The caching parameters page defines parameters that affect the use of the cache. 

• IC(lnitiator Control) bit of one specifies that the drive will honor the following parameters to control cache 
segmentation and pre-fetch: SIZE, FSW, LBCSS, Number of Cache Segments, Cache Segment Size. The drive 
will never pre-fetch less data than specified by ABPF, MF, Demand Read Retention Priority, Write Retention 
Priority, Disable Pre-fetch Transfer Length, Minimum Pre-fetch, Maximum Pre-fetch, and Maximum Pre-fetch 
Ceiling, but may pre-fetch more based on internal cache algorithms. When the 1C bit is set to zero, all the 
parameters listed above are ignored, and an internal caching algorithm is used. 

• ABPF (Abort Pre-fetch) bit of one, with DRA set to zero, causes the drive to abort the pre-fetch upon receipt of 
a new command. ABPF set to one takes precedence over Minimum Pre-fetch. When ABPF is zero, with DRA 
set to zero, the termination of any active pre-fetch is dependant upon the other parameters in this page. 

• CAP (Caching Analysis Permitted) is not supported and is ignored. The 1C bit can be used to enable or disable 
adaptive caching. 

• DISC (Discontinuity) is not supported and is ignored. Pre-fetch operations will continue across cylinders, within 
the limits of other caching parameters on this page. 

• SIZE (Size Enable) bit when set to one indicates that the Cache Segment Size is to be used to control caching 
segmentation. When SIZE is set to zero, the Initiator requests that the Number of Cache Segments is to be used 
to control caching segmentation. 

• WCE (Write Cache Enable) bit when set at zero indicates that the drive must issue Good status for WRITE (6) 
or WRITE (10) command only after successfully writing the data to the media. When the WCE bit is set to one, 
the drive may issue Good status for a WRITE (6) or WRITE (10) command after successfully receiving the data 
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but before writing it to the media. When WCE = 1, the drive operates as if AWRE = 1. 

Note: When WCE = 1, a SYNCHRONIZE CACHE command must be done to ensure data are written to the media before 
powering down the Target. 

WCD (Write Cache Disable) bit when set at zero treats that the drive Write Cache Enable. 

MF (Multiplication Factor) bit determines how the Maximum and Minimum Pre-fetch parameters are interpreted. 
If this bit is set to zero, the parameters are used as is. If the bit is set to one, the parameters are multiplied by 
the number of blocks requested in the Read Command. 

RCD (Read Cache Disable) bit set at zero indicates that the drive may return some or all of the data requested 
by a READ (6) or READ (10) command by accessing the data buffer, not the media. An RCD bit set at one 
indicates that the Target does not return any of the data requested by a READ (6) or READ (10) command by 
accessing the data buffer. All of the data requested is read from the media instead. 

Demand Read Retention Priority is not supported. 

Write Retention Priority is not supported. 

Disable Pre-fetch Transfer Length is used to prevent read-ahead after Read commands that are longer than 
the specified number of blocks. If this parameter is set to zero, a read-ahead is not performed. 

Minimum Pre-fetch specifies the minimum number of LBAs that the drive should after each READ command. 
A value of zero indicates that read ahead should be terminated immediately after a new command arrives, except 
when the new command is on the current head and track. 

Maximum Pre-fetch specifies the maximum number of LBAs to read ahead after a Read command. 

Maximum Pre-fetch Ceiling specifies the maximum number of blocks the drive should attempt to read ahead. 
This field is ignored. 

FSW (Force Sequential Write) is not supported and is ignored. All logical blocks will be written in sequential 
order. 

LBCSS (Logical Block Cache Segment Size) bit when set to one indicates that the Cache Segment Size field 
units shall be interpreted as logical blocks. When it is set to zero, the Cache Segment Size field units shall be 
interpreted as bytes. 

DRA (Disable Read Ahead) bit when set to one request that the Target not read into the buffer any logical block 
beyond the addressed logical block(s). When it is set at zero, the Target may continue to read logical blocks into 
the buffer beyond the addressed logical block(s). 

Number of Cache Segments field is used to select the number of data buffer cache segments. This parameter 
is valid only when the SIZE bit is set at zero. It is ignored when SIZE is set at one. 

Cache Segment Size field indicates the requested segment size in Bytes or Blocks, depending upon the value 
of the LBCSS bit. The Cache Segment Size field is valid only when the SIZE bit is one. It is ignored when SIZE 
is set at zero. 

Non Cache Segment Size is not supported and is ignored. 


HGST Hard Disk Drive OEM Specification 
147 



8.11.9 Mode Page OA (Control Mode Page Parameters) 


Table 144 Page OA (Control Mode Page Parameters) 


Byte 

Bit 

Default 

7 

6 

5 4 3 2 1 0 

0 

PS 

0 

Page Code = OAh 

8Ah 

1 

Page Length = OAh 

OAh 

2 

TST=0 

TMFonly=0 

DPICZ 

D_Sense GLTSD=0 

O 

II 

O 

DC 

04h 

3 

Queue Algorithm Modifier 

Rsvd=0 

QErr 

DQue 

OOh 

4 

RSVD=0 

RAC=0 

UA_INTLCK_CTRL=0 

SWP=0 

Obsolete 

OOh 

5 

ATO 

TAS=0 

ATM PE 

RWWP 

Rsvd=0 

Obsolete 

OOh 

6-7 

Obsoiete=0 

OOh 

8-9 

(MSB) Busy Timeout Period(LSB) 

OOh 

10-11 

(MSB)Extended Self-test Routine Completion Time(LSB) 

XXh 


Following are parameter options for Page OA. 

The Descriptor Sense Data (D SENSE) bit controls the format in which the drive returns sense data for 
CHECKCONDITION status: 

- Setting the D SENSE bit to 0 specifies that the drive shall return fixed format sense data for CHECK_CONDITION. 

- Setting the D_SENSE bit to 1 specifies that the drive shall return descriptor format sense data for 
CHECKCONDITION 

• DPICZ (Disable Protection Information Check if protect field is Zero) bit set to zero indicates that checking of 
protection information bytes is enabled. A DPICZ bit set to one indicates that checking of protection information 
is disabled on commands with: 

a) The RDPROTECT field (see SBC-3) set to zero; 

b) The VRPROTECT field (see SBC-3) set to zero; or 

c) The ORPROTECT field (see SBC-3) set to zero. 

• Queue algorithm modifier specifies restrictions on the algorithm used for reordering commands that are tagged 
with the SIMPLE message. 

Oh: Restricted reordering. The Target shall reorder the actual execution sequence of the queued commands 
from each Initiator such that data integrity is maintained for that Initiator. 

1h: Unrestricted reordering allowed. The Target may reorder the actual execution sequence of the queued 
commands in any manner it selects. Any data integrity exposures related to command sequence order are 
explicitly handled by the Initiator through the selection of appropriate commands and queue tag messages. 
2h-7h: RESERVED. 

8: Command reordering is disabled 
9-Fh: RESERVED 

• QErr (Queue Error Management) The queue error management (QERR) field specifies how the drive shall 
handle blocked tasks when another task receives a Check Condition status. 
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Table 145 Queue Error Management (QERR) field 


QERR value 

Description 

00b 

Specifies that all tasks from all Initiators are blocked from execution when a Continent Allegiance 
(CA condition) is pending. Those blocked tasks are allowed to resume execution in a normal fashion 
after the CA condition is cleared. 

01b 

Specifies that all tasks from all Initiators are aborted when the Target returns Check Condition 
status. A unit attention condition will be generated for each Initiator that had commands in the 
queue except for the Initiator that received the Check Condition status. The sense key will be set 
to Unit Attention and the additional sense code will be set to Commands Cleared by Another 
Initiator. 

10b 

Reserved 

11b 

Blocked tasks in the task set belonging to the Initiator to which a Check Condition status is sent 
shall be aborted when the status is sent. 


• DQue (Disable Queuing) bit set at zero specifies that tagged queuing shall be enabled if the Target supports 
tagged queuing. A DQue bit set at one specifies that tagged queuing shall be disabled. Command queuing is 
always enabled on the drive, therefore this bit is ignored. 

• ATO (Application Tag Owner) bit set to one specifies that the contents of the Logical Block Application Tag field 
in the protection information, if any, shall not be modified by the drive. An ATO bit set to zero specifies that the 
contents of the Logical Block Application Tag field in the protection information, if any, may be modified by the 
drive. If the ATO bit is set to zero, the drive will ignore the contents of the Logical Block Application Tag field in 
the protection information. 

• ATMPE (Application Tag Mode Page Enabled) bit set to zero specifies that the Application Tag mode page (see 
SBC-3) is disabled and the contents of logical block application tags are not defined by this standard. An ATMPE 
bit set to one specifies that the Application Tag mode page is enabled. 

If: 

a. the ATMPE is set to one; 

b. the ATO bit is set to one; 

c. the value in the DPICZ bit allows protection information checking for the specified command; and 

d. the APP CHK bit is set to one in the Extended Inquiry VPD page; 
then: 

knowledge of the value of the Application Tag shall come from the values in the Application Tag mode page as 
specified by the DPICZ bit. 

• RWWP(Reject Write Without Protection) bit set to zero specifies that write commands without protection 

• information(see SBC-3) shall be processed. A RWWP bit set to one specifies that write commands without 
protection information received by a drive that has been formatted with protection information shall be terminated 
with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code 
set to INVALID FIELD IN CDB 

The ATMPE bit enables the usage of another Mode whose definition from SBC 3r26 is as follows: 
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8.11.9.1 Control Extension Subpage Olh 


Table 146 Control Extension Subpage 


Byte 

Bit 

Default 

7 

6 

5 4 3 2 1 0 

0 

PS 

SPF=1 

Page Code = OAh 

4Ah 

1 

Subpage Code = 1 

Olh 

2-3 

Page Length = 001 Ch 

001 Ch 

4 

Reserved = 0 TCMOS=0 SCSIP=0 IALUAE = 0 

OOh 

5 

Reserved = 0 Initial Priority = 0 

OOh 

6 

Maximum Sense Data Length 

OOh 

7-31 

Reserved = 0 

OOh 


TCMOS (Timestamp Changeable By Methods Outside This Standard): set to zero to specify that the 
timestamp shall not be changed by any method except those defined by this standard. 

SCSIP (SCSI Precedence): set to zero to specify that methods outside this standard may change the timestamp 
and that the SET TIMESTAMP command is illegal. 

IALUAE (Implicit Asymmetric Logical Unit Access Enabled): set to zero to specify that implicitly managed 
transitions between primary target port asymmetric access states are disallowed and indicates that implicitly 
managed transitions between primary target port asymmetric access states are disallowed or not supported. 
Initial Command Priority: set to zero to indicate that the drive does not support priorities with the SET 
PRIORITY command. 

Maximum Sense Data Length: specifies the maximum number of bytes of sense data the drive shall return in 
the same l_T_L_Q nexus transaction as the status. A Maximum Sense Data Length field set to zero specifies 
that there is no limit. The drive shall not return more sense data bytes in the same l_T_L_Q nexus transaction 
as the status than the smaller of the length indicated by the: 

a) Maximum Sense Data length field; and 

b) Maximum Supported Sense Data Length field in the Extended INQUIRY VPD page (Page 86h). 
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8.11.9.2 Control Extension Subpage 02h 


Table 147 Application Tag mode page: 


Byte 

Bit | 

7 

6 

5 4 3 2 1 0 

0 

PS 

SPF=1 

Page Code = OAh 

1 

Subpage Code = 02h 

2-3 

Page Length = n-4 

4-15 

Reserved = 0 

16-39 

Application Tag descriptor [first] 



(n-24)-n 

Application Tag descriptor [last] 


Table 148 Application Tag descriptor format 


Byte 

Bit | 

7 

6 | 5 | 4 | 3 | 2 | 1 | 0 

0 

Last 

Reserved = 0 

1-5 

Reserved = 0 

6-7 

Logical Block Application Tag 

8-15 

Logical Block Address 

16-23 

Logical Block Count 


• A LAST bit set to one specifies that this Application Tag descriptor is the last valid Application Tag descriptor in 
the Application Tag mode page. A LAST bit set to zero specifies that the Application Tag descriptor is not the 
last valid Application Tag descriptor in the Application Tag mode page. 

• The LOGICAL BLOCK APPLICATION TAG field specifies the value to be compared with the LOGICAL LOCK 
APPLICATION TAG field associated with data read or written to the LBA. 

• The LOGICAL BLOCK ADDRESS field contains the starting LBA for this Application Tag descriptor. The 
LOGICAL BLOCK ADDRESS field in the first Application Tag descriptor shall be set to 0000_0000_0000_0000h. 
For subsequent Application Tag descriptors, the contents of the LOGICAL BLOCK ADDRESS field shall contain 
the sum of the values in: 

a) The LOGICAL BLOCK ADDRESS field in the previous Application Tag descriptor; and 

b) The LOGICAL BLOCK COUNT field in the previous Application Tag descriptor. 

The sum of the LOGICAL BLOCK ADDRESS field in the Application Tag descriptor with the LAST bit set to one and 
the LOGICAL BLOCK COUNT field in the Application Tag descriptor with the LAST bit set to one shall equal the 
RETURNED LOGICAL BLOCK ADDRESS field in the READ CAPACITY (16) parameter data (see 8.24 “READ 
CAPACITY (16)”). 

If an invalid combination of the LAST bit, LOGICAL BLOCK APPLICATION TAG field, and LOGICAL BLOCK 
ADDRESS field are sent by the application client, then the drive shall terminate the MODE SELECT command(see 
SPC-4) with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense 
code set to INVALID FIELD IN PARAMETER LIST. 

• The LOGICAL BLOCK COUNT field specifies the number of logical blocks to which this Application Tag 
descriptor applies. 

• A LOGICAL BLOCK COUNT field set to 0000_0000_0000_0000h specifies that this Application Tag descriptors 
hall be ignored. 

• Busy Timeout Period is not supported and is ignored. 

• Extended Self-test Routine Completion Time is an advisory parameter that an Initiator may use to determine 
the time in seconds that the Target requires to complete self-test routine when the Target is not interrupted by 
an Initiator and no errors occur during execution of the self-test routine. 
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8.11.10 Mode Page 0C (Notch Parameters) 


Table 149 Page 0C (Notch Parameters) 


Byte 

Bit 

Default 

7 

6 

5 4 3 2 1 0 

0 

PS 

0 

Page Code = OCh 

8Ch 

1 

Page Length = 16h 

16h 

2 

ND=1 LPN=0 Reserved = 0 

80h 

3 

Reserved = 0 

OOh 

4-5 

(MSB) 

Maximum Number of Notches 

(LSB) 

XXh 

XXh 

6-7 

(MSB) 

Active Notch 

(LSB) 

OOh 

OOh 

8-11 

(MSB) 

Starting Boundary 

(LSB) 

XXh 

XXh 

12-15 

(MSB) 

Ending Boundary 

(LSB) 

XXh 

XXh 

16-23 

(MSB) 

Pages Notched 

(LSB) 

OOOOh 

OOOOh 

OOOOh 

lOOCh 


The notch page contains parameters for direct-access devices that implement a variable number of blocks per 
cylinder. Each section of the logical unit with a different number of blocks per cylinder is referred as a notch. The only 
field that is changeable is the Active Notch field. 

• ND = One meaning that this device is a notched drive. 

• LPN = Zero meaning that the notches are based upon physical parameters of the drive (cylinder #), not logical 
parameters. 

• Maximum Number of Notches is the number of notches the drive can support. This value is drive model 
dependent. 

• Active Notch indicates to which notch subsequent MODE SELECT/SENSE command parameters pertain. A 
value of 0 is used for parameter values which apply to all notches. Values from 1 to the maximum value 
depending on the model specify the notch number, where notch 1 is the outermost notch. Following mode 
parameters are based on the current active notch: 

• Mode Page 2 

- Read Buffer Full Ratio 

- Write Buffer Empty Ratio 
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• Mode Page 3 

- Alternate Sector per Zone 

- Alternate Track per Zone 

- Alternate Track per Logical Unit 

- Sector per Track 

- Track Skew Factor 

- Cylinder Skew Factor 

• Starting Boundary contains the first physical location of the active notch. The first three bytes are the cylinder 
number and the last byte is the head. The value sent in this field is ignored. 

• Ending Boundary contains the last physical location of the active notch. The first three bytes are the cylinder 
number and the last byte is the head. The value sent in this field is ignored. 

• Pages Notched is a bit map of the mode page codes that indicates which pages contain parameters that may 
be different for different notches. The most significant bit of this field corresponds to page code 3Fh and the least 
significant bit corresponds to page code OOh. If a bit is one, then the corresponding mode page contains 
parameters that may be different for different notches. If a bit is zero, then the corresponding mode page contains 
parameters that are constant for all notches. 

8.11.11 Mode Page 18h 


Table 150 Page 18h (Protocol-Specific Logical Unit mode page) 


Byte 

Bit 

Default 

7 

6 

5 4 3 2 1 0 

0 

PS=0 

SPF=0 

Page Code = 18h 

18h 

1 

Page Length = 6h 

6h 

2 

Reserved 

Transport Layer Retries=0 Protocol Identifier = 6h 

6h 

3 

Reserved = 0 

OOh 

4-7 

Reserved 

OOh 


This page defined protocol-specific parameters that affect the logical unit. 

• Transport Layer Retries is unchangeable and set to zero. The drive does not support Transport Layer Retries as 
defined in SAS 1.1. 
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8.11.12 Mode Page 19h (Port Control Parameters) 

The Protocol-Specific Port mode page contains parameters that affect SSP target port operation. There is one copy 
of the mode page shared by all SSP initiator ports. 

8.11.12.1 Short Format of Port Control Page 


Table 151 Short (Port Control Parameters) Short Format 


Byte 

Bit 

Default 

7 

6 

5 | 4 | 3 | 2 | 1 | 0 

0 

PS 

SPF=0 

Page Code = 19h 

99h 

1 

Page Length = OEh 

OEh 

2 

Reserved 

Continue 

AWT 

Broadcast 

Asynchronous 

Event 

Ready LED 
Meaning 

Protocol Identifier = 6h 

06h 

3 

Reserved 

OOh 

4-5 

(MSB) 

l_T NEXUS LOSS TIMER 

(LSB) 

07h-D0h 

6-7 

(MSB) 

INITIATOR RESPONSE TIMEOUT 

(LSB) 

07h-D0h 

8-9 

(MSB) 

REJECT TO OPEN LIMIT 

(LSB) 

OOOOh 

10-15 

Reserved 

OOh 


• The Parameters Savable (PS) bit is set to one, indicating the parameters are saveable. 

• The SPF field shall be set to zero for access to the short format mode page. 

• Protocol Identifier has a value of 6h indicating this is a SAS SSP specific mode page. 

• A CONTINUE AWT bit set to one specifies that the SAS port shall not stop the Arbitration Wait Time timer and 
set the Arbitration Wait Time timer to zero when the SAS port receives an OPENREJECT (RETRY). A 
CONTINUE AWT bit set to zero specifies that the SAS port shall stop the Arbitration Wait Time timer and set the 
Arbitration Wait Time timer to zero when it receives an OPEN_REJECT (RETRY). 

• A BROADCAST ASYNCHRONOUS EVENT bit set to one specifies that the drive shall enable origination of 
Broadcast (Asynchronous Event). A BROADCAST ASYNCHRONOUS EVENT bit set to zero specifies that the 
drive shall disable origination of Broadcast (Asynchronous Event). 

• Ready LED Meaning specifies the READY LED signal behavior. In general, when the bit is 0, and the drive is 
in a ready state, the LED is usually on, but flashes on and off when commands are processed. When the bit is 
1, the LED is usually off, but flashes on and off when commands are processed. For additional implementation 
specifics, see the SAS 2 draft standard. 

• The I T NEXUS LOSS TIME field contains the time (in milliseconds) that our SSP target port shall retry 
connection requests to an SSP initiator port that are rejected with responses indicating the SSP initiator port may 
no longer be present before recognizing an l_T nexus loss. A value of 0 indicates a vendor specific amount of 
time and defaults to a 2 second time period. A value of FFFFh indicates an unlimited period. The default value 
of 7D0h specifies a 2 second time period. 

• INITIATOR RESPONSE TIMEOUT field contains the time in milliseconds that the SSP target port shall wait for 
the receipt of a Data frame after sending the XFER_RDY frame requesting data. When the INITIATOR 
RESPONSE TIMEOUT expires, the associated command will be aborted. An INITIATOR RESPONSE TIMEOUT 
field value of zero indicates that the SSP target port shall disable the timer. This value is enforced by the transport 
layer. The default value of 7D0h specifies a 2 second time period. 
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• The REJECT TO OPEN LIMIT field contains the minimum time in 10 ps increments that the target port shall wait 
to establish a connection request with an initiator port on an l_T nexus after receiving an OPEN_REJECT 
(RETRY), OPENREJECT (CONTINUE 0), or OPENREJECT (CONTINUE 1). This value may be rounded as 
defined in SPC-4. A REJECT TO OPEN LIMIT field set to OOOOh indicates that the minimum time is vendor 
specific. This minimum time is enforced by the transport layer. 

8.11.12.2 Long Format of Port Control Page 


Table 152 Long Format of Port Control Page 


Byte 

Bit 

Default 

7 

6 

5 4 3 2 1 0 

0 

PS 

SPF=1 

Page Code = 19h 

D9h 

1 

Subpage Code 


2-3 

(MSB) 

Page Length (n-3) 

(LSB) 

OOOOh 

4 

RSVD 

OOh 

5 

RSVD Protocol Identifier = 6h 

06h 

6 

Protocol Specific Mode Parameters 


n 



The drive maintains an independent set of port control mode page parameters for each SAS initiator port. 

• The SPF field shall be set to one for access to the long format mode page. 

• Subpage Code indicates which subpage is being accessed. The drive support the following subpage codes. If 
the Subpage Code is not supported, the drive returns a CHECK CONDITION status, the sense key is set to 
ILLEGAL REQUEST and the additional sense code set to ILLEGAL FIELD IN PARAMETER LIST. 

- 01 h: PHY Control and Discover Subpage 

- 02h: Shared Port Control subpage 

- FFh: All supported subpages. 

• Page Length specifies the length in bytes of the subpage parameters after the Page Length. 

• Protocol Identifier has a value of 6h indicating this is a SAS SSP specific mode page. 
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8.11.12.3 PHY Control and Discover (Subpage l) 


Table 153 PHY Control and Discover (Subpage 1) 


Byte 

Bit 

Default 

7 

6 

5 4 3 2 1 0 

0 

PS 

SPF=1 

Page Code = 19h 

D9h 

1 

Subpage Code = 1 

01 h 

2-3 

(MSB) 

Page Length = 0064h 

(LSB) 

0064h 

4 

Reserved 

OOh 

5 

Reserved Protocol Identifier = 6h 

06h 

6 

Generation Code 

OOh 

7 

Number of PHYS = 2 

02h 

8-55 

SAS PHY Mode Descriptor 0 


56-103 

SAS PHY Mode Descriptor 1 



The Phy Control and Discover subpage contains phy-specific parameters. MODE SENSE command returns the 
current settings for the initiator. 

• Protocol Identifier has a value of 6h indicating this is a SAS SSP specific mode page. 

• The GENERATION CODE field is a one-byte counter that shall be incremented by one by the drive every time 

the values in this mode page or the SAS-2 Phy mode page (see 10.2.7.7) field values are changed. A 
GENERATION CODE field set to OOh indicates the generation code is unknown. The drive shall wrap this field 
to 01 h as the next increment after reaching its maximum value (i.e., FFh). The GENERATION CODE field is also 
contained in the Protocol-Specific Port log page and may be used to correlate phy settings across mode page 
and log page accesses. 

• Number of PHYS field is set to 2, to represent the dual ported drive (one PFIY per port) 

• The SAS PHY Mode Descriptor Fields are defined in Table 154. There are two SAS PFIY Mode Descriptor 

fields, one per port. 
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Table 154 SAS PHY Mode Descriptor 


Byte 

Bit 

7 6 5 4 3 2 1 0 

0 

Reserved 

1 

PHY IDENTIFIER 

2-3 

(MSB) 

Reserved 

(LSB) 

4 

Reserved ATTCHED DEVICE TYPE 

ATTCHED REASON 

5 

Reason 

Negotiated Logical Link Rate 

6 

Reserved 

ATTACHED 

SSP 

INITIATOR 

PORT 

ATTACHED 

STP 

INITIATOR 

PORT 

ATTACHED 

SMP 

INITIATOR 

PORT 

Reserved 

7 

Reserved 

ATTACHED 

SSP 

TARGET 

PORT 

ATTACHED 

STP 

TARGET 

PORT 

ATTACHED 

STP 

TARGET 

PORT 

Reserved 

8-15 

(MSB) 

SAS ADDRESS 

(LSB) 

16-23 

(MSB) 

ATTACHED SAS ADDRESS 

(LSB) 

24 

ATTACHEDPHY IDENTIFIER 

25-31 

(MSB) 

Reserved 

(LSB) 

32 

PROGRAMMED MINIMUM PHYSICAL 
LINK RATE 

HARDWARE MINIMUM PHYSICAL LINK RATE 

33 

PROGRAMMED MAXIMUM PHYSICAL 
LINK RATE 

HARDWARE MAXIMUM PHYSICAL LINK RATE 

34-41 

(MSB) 

Reserved 

(LSB) 

42-43 

(MSB) 

Vendor specific 

(LSB) 

44-47 

(MSB) 

Reserved 

(LSB) 


PHY Identifier: Unique PHY Identifier for the PHY associated with the other data in this SAS PHY Mode 
Descriptor Page. 

Attached Reason: indicates the value of the REASON field in the last received IDENTIFY address frame 
associated with the PHY Identifier list in this SAS PHY Mode Descriptor. 

Attached Device Type: indicated the value of the DEVICE TYPE field in the last received IDENTIFY address 
frame associated with the PHY Identifier listed in this SAS PHY Mode Descriptor. 
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• Attached SAS Address: indicates the value of the attached SAS address in the last received IDENTIFY address 
frame associated with the PHY Identifier list in this SAS PHY Mode Descriptor.. 

• Attached PHY Identifier: indicated the value of the attached PHY Identifier field in the last received IDENTIFY 
address frame associated with the PHY Identifier listed in this SAS PHY Mode Descriptor. 

• SAS Address: Unique Port Identifier for the Port associated with the PHY Identifier listed in this SAS PHY Mode 
Descriptor 

• Hardware Minimum Physical Link Rate: Minimum link rate supported by the Port associated with the PHY 
Identifier listed in this SAS PHY Mode Descriptor. 

• Hardware Maximum Physical Link Rate: Maximum link rate supported by the Port associated with the PHY 
Identifier listed in this SAS PHY Mode Descriptor. 

• Programmed Minimum Physical Link Rate: Current minimum link rate used during speed negotiation by the 
Port associated with the PHY Identifier listed in this SAS PHY Mode Descriptor. 

• Programmed Maximum Physical Link Rate: Current maximum link rate used during speed negotiation by the 
Port associated with the PHY Identifier listed in this SAS PHY Mode Descriptor. 

8.11.12.4 Shared Port Control (Subpage 2) 


Table 155 Shared Port Control (Subpage 2) 


Byte 

Bit 

Default 

7 

6 

5 4 3 2 1 0 

0 

PS 

SPF=1 

Page Code = 19h 

D9h 

1 

Subpage Code = 2 

02h 

2-3 

Page Length = OOOCh 

OOOCh 

4 

Reserved = 0 

OOh 

5 

Reserved = 0 Protocol Identifier = 6 

06h 

6-7 

Power Loss Timeout 

OOOOh 

8-15 

Reserved = 0 

OOh 


Power Loss Timeout is the maximum time, in one millisecond increments, that the drive port will respond to 
connection requests with OPENREJECT(RETRY) after receiving NOTIFY(POWER LOSS EXPECTED).The 
Power Loss Timeout will be restarted after each NOTIFY(POWER LOSS EXPECTED) that is received. A 
POWER LOSS TIMEOUT field set to OOOOh specifies that the maximum time is vendor-specific and automatically 
defaults to 2 seconds. 
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8.11.12.5 SAS-2 Phy Mode Page (Subpage 3) 


Table 156 Subpage 3 


Byte 

Bit 

Default 

7 

6 

5 4 3 2 1 0 

0 

PS 

SPF=1 

Page Code 19h 

D9h 

1 

Subpage Code = 3 

03h 

2-3 

Page Length = 002Ch 

002Ch 

4 

Reserved = OOh 

OOh 

5 

Reserved = 0 Protocol Identifier = 6 

06h 

6 

Generation Code 

OOh 

7 

Number of Phys = 02h 

02h 

8-27 

SAS-2 PHY Mode Descriptor 0 


28-47 

SAS-2 PHY Mode Descriptor 1 



The GENERATION CODE field is a one-byte counter that shall be incremented by one by the drive every time 
the values in this mode page or the SAS-2 Phy mode page (see 10.2.7.7) field values are changed. A 
GENERATION CODE field set to OOh indicates the generation code is unknown. The drive shall wrap this field 
to 01 h as the next increment after reaching its maximum value (i.e., FFh). The GENERATION CODE field is also 
contained in the Protocol-Specific Port log page and may be used to correlate phy settings across mode page 
and log page accesses. 


Table 157 PHY Mode Descriptor (0 and 1) 


Byte 

Bit 

7 6 5 4 3 21 0 

0 

Reserved 

1 

PHY Identifier 

2-3 

Descriptor Length (001 Oh) 

4-7 

Programmed PHY Capabilities 

8-11 

Current PHY Capabilities 

12-15 

Attached PHY Capabilities 

16-17 

Reserved 

18 

Reserved Negotiated SSC Negotiated Physical Link Rate 

19 

“ x ;" 9 


• Phy Capabilities are defined under the “SAS Speed Negotiation” 
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8.11.13 Mode Page 1A (Power Control) 


Table 158 Page 1A (Power Control) 


Byte 

Bit 

Default 

7 

6 

5 | 4 | 3 | 2 | 1 | 0 

0 

PS 

SPF (0b) 

Page Code = 1 Ah 

9Ah 

1 

Page Length = 26h 

26h 

2 

PM_BG_PRECEDENCE Reserved = 0 

Standby_Y 

OOh 

3 

Reserved = 0 ldle_C ldle_B ldle_A 

Standby_Z 

06h 

4-7 

ldle_A Condition Timer 

14h 

8-11 

Standby_Z Condition Timer 

OOh 

12-15 

Idle_B Condition Timer 

1770h 

16-19 

ldle_C Condition Timer 

OOh 

20-23 

Standby_Y Condition Timer 

OOh 

24-38 

Reserved 

OOh 

39 

CCFJDLE CCF_STANDBY CCF_STOPPED Reserved 

58h 


• If the STANDBY_Y bit is set to one, then the standby_y condition timer is enabled. If the STANDBY Y bit is set 
to zero, then the device shall ignore the standby_y condition timer. 

• If the IDLE_C bit is set to one, then the idle_c condition timer is enabled. If the IDLE_C bit is set to zero, then 
the device shall ignore the idle_c condition timer. 

• If the IDLE_B bit is set to one, then the idle_b condition timer is enabled. If the IDLE_B bit is set to zero, then 

the device shall ignore the idle_b condition timer. 

• If the IDLE_A bit is set to one, then the idle_a condition timer is enabled. If the IDLE A bit is set to zero, then 

the device shall ignore the idle_c condition timer. 

• If the STANDBY_Z bit is set to one, then the standby_z condition timer is enabled. If the STANDBY Z bit is set 
to zero, then the device shall ignore the standby_z condition timer. 

• The IDLE_A Condition Timer field specifies the initial value, in 100 millisecond increments, for the idle_a power 
condition timer. The minimum allowable inactivity time for idle_a is 1 second. Any value less than this is accepted, 
but will automatically default to 1 second. 

• The STANDBY_Z Condition Timer field specifies the initial value, in 100 millisecond increments, for the 
standby_z power condition timer. The minimum allowable inactivity time for standby_z is 2 minutes. Any value 
less than this is accepted, but will automatically default to two minutes. In addition, a limit of 60 timer initiated 
head unloads per 24 hour period is enforced. 

• The IDLE_B Condition Timer field specifies the initial value, in 100 millisecond increments, for the idle_b power 

condition timer. The minimum allowable inactivity time for idle_b is 2 minutes. Any value less than this is accepted, 

but will automatically default to two minutes. In addition, a limit 60 timer initiated head unloads per 24 hour period 
is enforced. 

• The IDLE_C Condition Timer field specifies the initial value, in 100 millisecond increments, for the idle_c power 
condition timer. The minimum allowable inactivity time for idle_c is 2 minutes. Any value less than this is accepted, 
but will automatically default to two minutes. In addition, a limit of 60 timer initiated head unloads per 24 hour 
period is enforced. 

• The STANDBY_Y Condition Timer field specifies the initial value, in 100 millisecond increments, for the 
standby_y power condition timer. The minimum allowable inactivity time for standby_y is 2 minutes. Any value 
less than this is accepted, but will automatically default to two minutes. In addition, a Iimit60 timer initiated head 
unloads per 24 hour period is enforced. 

• The PM_BG_PRECEDENCE field (see Table 159) specifies the interactions between background functions and 
power management 

• CCF Idle CHECK CONDITION if from idle, 00b: restricted. 01b Returning CHECK CONDITION status if transition 
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was from an idle power condition is disabled. 10b: Returning CHECK CONDITION status if transition was from 
an idle power condition is enable, 11b: reserved. 

CCF Standby CHECK CONDITION if standby, 00b: restricted. 01b: Returning CHECK CONDITION status if 
transition was from a standby power condition is disabled. 10b: Returning CHECK CONDITION status if 
transition was from a standby power condition is enabled, 11b: reserved 

CCF Stopped CHECK CONDITION if stopped, 00b: restricted. 01b: Returning CHECK CONDITION status if 
transition was from a stopped power condition is disabled. 10b: Returning CHECK CONDITION status if 
transition was from a stopped power condition is enabled, 11 b: reserved 
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Table 159 PM_BG_PRECEDENCE field 


Code 

Vendor Specific 

OOh 

PS 

01b 

Performing background functions take precedence over maintaining low power conditions as follows: 

a) if the logical unit is in a low power condition as the result of a power condition timer associated with 
that condition expiring, then: 

1) the logical unit shall change from that power condition, if necessary, to the power condition required 
to perform the background function, when: 

a) a timer associated with a background scan operation expires, and that function is enabled or 

b) an event occurs to initiate a device specific background function, and that function is enabled; 

2) the logical unit shall perform the background function(s) based on the definitions in this standard 
and other command standards (e.g., if the drive receives a command while performing a 
background function, then the logical unit shall suspend the function to process the command); 

3) if more than one condition is met to initiate a background function, then: 

a) all initiated background functions shall be performed; and 

b) the order of performing the functions is vendor specific; and 

4) when all initiated background functions have been completed, the drive shall check to see if any 
power condition timers have expired. If any power condition timer has expired, then the logical 
unit shall change to the power condition associated with the highest priority timer that has 
expired; 

or 

b) if the logical unit is performing a background function, and a power condition timer expires, then the 
logical unit shall perform all initiated background functions before the logical unit changes to a power 
condition associated with a timer has expired 

10b 

Maintaining low power conditions take precedence over performing background functions as follows: 

a) if the logical unit is in a low power condition, then the logical unit shall not change from that power 
condition to perform a background function; 

b) the drive may perform any initiated and enabled background function based on the definitions in this 
standard or other command standards, if all of the following are true: 

A) a condition is met to initiate a background function; 

B) that background function is enabled; 

C) the logical unit changes to a power condition in which the background function may be performed 
(e.g., the drive processes a medium access command causing the logical unit to change its power 
condition to continue processing that command); and 

D) all outstanding application client requests have been completed; 

or 

c) if the logical unit is performing a background function, and a power condition timer expires that causes 
a change to a power condition in which the logical unit is unable to continue performing the 
background function, then the logical unit shall: 

A) suspend the background function; and 

B) change to the power condition associated with the timer that expired. 

11b 

Reserved = 0 


HGST Hard Disk Drive OEM Specification 
162 




8.11.14 Mode Page 1C (Informational Exceptions Control) 


Table 160 Page 1C (Informational Exceptions Control) 


Byte 

Bit 

Default 

7 

6 

5 4 3 2 1 0 

0 

PS 

0 

Page Code = ICh 

9Ch 

1 

Page Length = OAh 

OAh 

2 

PERF 

RSVD 

EBF EWASC 

DEXCPT TEST LOGERR 

lOh 

3 

Reserved = 0 

Method of Reporting 

03h 

4-7 

(MSB) 

Interval Timer 

(LSB) 

OOh 

OOh 

OOh 

OOh 

8-11 

(MSB) 

Report Count 

(LSB) 

OOh 


• PERF (Performance) bit is not supported and is ignored. Informational Exception operations will not cause 
performance delays. 

• EBF (Enable Background Function) bit is not supported and is ignored. Background functions are always 
enabled. 

• EWASC (Enable Warning ASC) bit of zero indicates that Temperature Warnings will not be reported. An EWASC 
bit of one allows Temperature Warnings to be reported, if the temperature inside the disk enclosure exceeds the 
threshold set in Mode Page OOh.The Method of Reporting field controls the reporting method. EWASC is 
independent of DEXCPT. 

• DEXCPT (Disable Exception Control) bit of zero indicates information exception operations are enabled. The 
reporting of information exception conditions when the DEXCPT bit is set to zero is determined from the Method 
of Reporting field. A DEXCPT bit of one indicates the Target disabled all information exception operations. 

• TEST bit of one instructs the drive to generate false drive notifications at the next interval time, (as determined 
by the INTERVAL TIMER field), if the DEXCPT is zero. The Method of Reporting and Report Count would apply. 
The false drive failure is reported as sense qualifier 5DFFh. The TEST bit of zero instructs the drive to stop 
generating any false drive notifications. 

• Enable Background Error (EBACKERR) bit of zero disables reporting of background self-test errors and 
background scan errors via Information Exceptions Control. An EBACKERR bit of one enables reporting of these 
background errors as Information Exception Warnings. The method of reporting these errors is determined from 
the MRIE field. 

• LOGERR (Log Errors) is not used and ignored internally by the Target. 

• Method of Reporting Informational Exceptions indicates the methods used by the Target to report informational 
exception conditions. 
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Table 161 Method of Reporting 


Code 

Description 

Oh 

No reporting of informational exception condition: This method instructs the Target to not 
report informational exception condition. 

1h 

Asynchronous event reporting: Not supported. 

2h 

Generate unit attention: This method instructs the Target to report informational exception 
conditions by returning a Check Condition status on any command. The sense key is set to Unit 
Attention and the additional sense code indicates the cause of the informational exception 
condition. The command that has the Check Condition is not executed before the informational 
exception condition is reported. 

3h 

Conditionally generate recovered error: This method instructs the Target to report 
informational exception conditions, dependent on the value of the PER bit of the error recovery 
parameters mode page, by returning a Check Condition status on any command. The sense key 
is set to Recovered Error and the additional sense code indicates the cause of the informational 
exception condition. The command that has the Check Condition completes without error before 
any informational exception condition is reported. 

4h 

Unconditionally generate recovered error: This method instructs the Target to report 
informational exception conditions, regardless of the value of the PER bit of the error recovery 
parameters mode page, by returning a Check Condition status on any command. The sense key 
is set to Recovered Error and the additional sense code indicates the cause of the informational 
exception condition. The command that has the Check Condition completes without error before 
any informational exception condition is reported. 

5h 

Generate no sense: This method instructs the Target to report informational exception conditions 
by returning a Check Condition status on any command. The sense key is set to No Sense and 
the additional sense code indicates the cause of the informational exception condition. The 
command that has the Check Condition completes without error before any informational 
exception condition is reported. 

6h 

Only report informational exception condition on request: This method instructs the Target 
to preserve the informational exception(s) information. To find out about information exception 
conditions the Application Client polls the Target by issuing an unsolicited Request Sense 
command. The sense key is set to No Sense and the additional sense code indicates the cause 
of the informational exception condition. 

7h-Fh 

Reserved. 


• Interval Timer field indicates the period in 100 millisecond increments for reporting that an informational 
exception condition has occurred. The target shall not report informational exception conditions more frequently 
than the time specified by the Interval Timer field and as soon as possible after the time interval has elapsed. 
After the informational exception condition has been reported the interval timer is restarted. A value of zero or 
OxFFFFFFFF in the Interval Timer field indicates that the target only reports the informational exception condition 
one time and will override the value set in the Report Count Field. 

• Report Count Field indicates the number of times the Target reports an informational exception condition. The 
Report Count of ZERO indicates no limits on the number of times the Target reports an informational exception 
condition. 
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8.11.14.1 Background Control (Subpage Olh) 


Table 162 Background Control (Subpage Olh) 


Byte 

Bit 

Default 

7 

6 

5 4 3 2 1 0 

0 

PS 

SPF=1 

Page Code = ICh 

DCh 

1 

Subpage Code = Olh 

Olh 

2-3 

Page Length = OCh 

OOOCh 

4 

Reserved = 0 S_L_Full LOWIR 

ENBMS 

Olh 

5 

Reserved = 0 

ENPS 

OOh 

6-7 

Background Medium Scan Interval Time 

00A8h 

8-9 

Background Pre-Scan Time Limit 

OOOOh 

10-11 

Minimum Idle Time Before Background Scan 

OOOOh 

12-13 

Maximum Time To Suspend Background Scan (Ignored) 

OOOOh 

14-15 

Reserved = 0 

OOOOh 


• Suspend On Log Full (S_L_FULL) bit set to zero allows background scans to continue if the results log (Log 
Sense Page 15h) is full.S_L_FULL bit set to one will cause background scans to suspend when the log is full. 

• Log Only When Intervention Required (LOWIR) bit set to zero allows logging of all medium errors in the results 
log (Log Sense Page 15h).When the LOWIR bit is set to one, only unrecovered medium errors will be logged. 

• EN_BMS (Enable Background Medium Scan) bit set to zero specifies that the background medium scan is 
disabled. EN_BMS bit set to one specifies that background medium scan operations are enabled. If a 
background medium scan is in progress when the ENBMS bit is changed from one to zero, then the medium 
scan shall be suspended until the EN BMS bit is set to one, at which time the medium scan shall resume from 
the suspended location. 

• EN_PS (Enable Pre-Scan) bit set to zero specifies that the pre-scan is disabled. If a pre-scan operation is in 
progress when EN_PS is changed from a one to a zero, then pre-scan is halted. An EN_PS bit set to one 
specifies that a pre-scan operation is started after the next power-on cycle. Once this pre-scan has completed, 
another pre-scan shall not occur unless the EN_PS bit is set to zero, then set to one, and another power-on 
cycle occurs. 

• Background Medium Scan Interval Time specifies the minimum time, in hours, between the start of one 
background medium scan operation and the start of the next background medium scan operation. 

• Background Pre-Scan Time Limit specifies the maximum time, in hours, for a pre-scan operation to complete. 
If the pre-scan operation does not complete within the specified time, then it is halted. A value of zero specifies 
an unlimited time limit. 

• Minimum Idle Time Before Background Scan specifies the minimum time, in milliseconds, that the drive must 
be idle before resuming a background media scan or pre-scan. A value of zero will be treated as the default 
value of 1.0 second. Any value less than 100 milliseconds will be treated as 100 milliseconds. The internal timer 
granularity is 50 milliseconds. 

• Maximum Time To Suspend Background Scan (Ignored). 
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8.12 MODE SENSE (5A) 


Table 163 Mode Sense (5A) 


Byte 

Bit 

765 

432 

10 

0 

Command Code = 5Ah 

1 

Reserved = 0 

LLBAA DBD 

Reserved = 0 

2 

PCF 

Page Code 


3 

Subpage code 

4-6 

Reserved = 0 

7-8 

(MSB) 

Allocation Length 

(LSB) 

9 

VU = 0 

Reserved = 0 

FLAG LINK 


The MODE SENSE (5A) command provides a means for the drive to report various device parameters to the initiator. 
See the MODE SENSE (1 A) command for a description of the fields in this command. 

• Long LBA Accepted (LLBAA) bit set to zero ensures that if a Block Descriptor is present it must be a Short 
LBA Block Descriptor. If the LLBAA bit is set to one, the Long LBA Block Descriptor may be used. 
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8.13 PERSISTENT RESERVE IN (5E) 


Table 164 Persistent Reserve In (5E) 


Byte 

Bit 

7 6 5 4 3 21 ° 

0 

Command Code = 5Eh 

1 

Reserved = 0 Service Action 

2-6 

Reserved = 0 

7-8 

(MSB) 

Allocation Length 

(LSB) 

9 

VU = 0 Reserved = 0 FLAG LINK 


The PERSISTENT RESERVE IN command is used to obtain information about persistent reservations and 
reservation keys that are active within the controller. This command is used in conjunction with the PERSISTENT 
RESERVE OUT command PERSISTENT RESERVE OUT (5F). 

The Allocation Length indicates how much space has been allocated for the returned parameter data. If the length 
is not sufficient to contain all parameter data, the first portion of the data will be returned. If the remainder of the 
data is required, the initiator should send a new PERSISTENT RESERVE IN command and an Allocation Length 
large enough to contain all data. 

8.13.1 Service Action 

The following service action codes are implemented. If a reserved service action code is specified, the drive returns 
a Check Condition status. The sense key is set to Illegal Request and the additional sense data is set to Invalid 
Field in CDB. 


Table 165 PERSISTENT RESERVE IN, Service Action Codes 


Code 

Name 

Descriptions 

OOh 

Read Keys 

Reads all registered Reservation Keys 

01 h 

Read Reservations 

Reads all current persistent reservations 

02h 

Report Capabilities 

Returns capability information 

03h 

Read Full Status 

Reads complete information about all registrations 
and the persistent reservation, if any 

04h-1 Fh 

Reserved 

Reserved 
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8.13.2 Parameter data for Read Keys 


Table 166 PERSISTENT RESERVE IN, parameter data for Read Keys 


Byte 

Bit 

7 6 5 4 3 2 1 0 

0-3 

(MSB) 

Generation 

(LSB) 

4-7 

(MSB) 

Additional length (n-7) 

(LSB) 

8-15 

(MSB) 

First reservation key 

(LSB) 



(n-7)- n 

(MSB) 

Last reservation key 

(LSB) 


Generation is a counter that increments when PERSISTENT RESERVE OUT command with “Register” or “Preempt 
and Clear” completes successfully. Generation is set to 0 as part of the power on reset process and hard reset 
process. 

The Generation field contains a 32-bit counter that the Target shall increment every time a PERSISTENT RESERVE 
OUT command requests a Register, a Clear, a Preempt, or a Preempt and Abort service action. The counter shall 
not be incremented by a PERSISTENT RESERVE IN command, by a PERSISTENT RESERVE OUT command that 
performs a Reserve or Release service action, or by a PERSISTENT RESERVE OUT command that is not performed 
due to an error or reservation conflict. Regardless of the APTPL value the generation value shall be set to 0 as part 
of the power on reset process. 

The Additional Length field contains a count of the number of bytes in the reservation key list. If the allocation length 
specified by the PERSISTENT RESERVE IN command is not sufficient to contain the entire parameter list, then only 
the bytes from 0 to the maximum allowed allocation length shall be sent to the Initiator. The incremental remaining 
bytes shall be truncated, although the Additional Length field shall still contain the actual number of bytes in the 
reservation key list without consideration of any truncation resulting from an insufficient allocation length. This shall 
not be considered an error. 

The Reservation Key list contains the 8-byte reservation keys for all Initiators that have registered through all ports 
with the Target. 
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8.13.3 Parameter Data for Read Reservations 


Table 167 PERSISTENT RESERVE IN, parameter data for Read Reservations 


Byte 

Bit 

7 6 5 4 3 2 1 0 

0-3 

(MSB) 

Generation 

(LSB) 

4-7 

(MSB) 

Additional length (n-7) 

(LSB) 

8-n 

(MSB) 

Reservation descriptors 

(LSB) 


The Generation field shall be as defined for the Persistent Reserve in Read Keys parameter data. The Additional 
Length field contains a count of the number of bytes to follow in the Reservation Descriptor(s). 

If the Allocation length specified by the PERSISTENT RESERVE IN command is not sufficient to contain the entire 
parameter list, then only the bytes from 0 to the maximum allowed allocation length shall be sent to the Initiator. The 
remaining bytes shall be truncated, although the Additional Length field shall still contain the actual number of bytes 
of the Reservation Descriptor(s) and shall not be affected by the truncation. This shall not be considered an error. 
The format of the Reservation Descriptors is defined in the Persistent Reserve in Reservation Descriptor table. 
There shall be a Reservation Descriptor for the persistent reservation, if any, present in the Target having a persistent 
reservation. 


Table 168 PERSISTENT RESERVE IN, Read Reservation Descriptor 


Byte 

Bit 

7 6 5 4 

3 2 10 

0-7 

(MSB) 

Reservation key 

(LSB) 

8-11 

(MSB) 

Scope-specific address 

(LSB) 

12 

Reserved 

13 

Scope=0 

Type 

14-15 

(MSB) 

Extent Length=0 

(LSB) 


The Scope of each persistent reservation created by a PERSISTENT RESERVE OUT command will be returned. 
See the PERSISTENT RESERVE OUT command section for details. 
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8.14 PERSISTENT RESERVE OUT (5F) 


Table 169 PERSISTENT RESERVE OUT (5F) 


Byte 

Bit 

7 6 

5 

4 

3 2 

1 

0 

0 

Command Code = 5Fh 

1 

Reserved = 0 

Service Action 

2 

Scope=0 

Type 

3-6 

Reserved = 0 

7-8 

Parameter List Length = 18h 

9 

vu = o 

Reserved = 0 

FLAG 

LINK 


The PERSISTENT RESERVE OUT command is used to request service actions that reserve the drive for the 
exclusive or shared use of the initiator. The command uses other service actions to manage and remove such 
reservations. This command is used in conjunction with the PERSISTENT RESERVE IN command, and should not 
be used with the RESERVE and RELEASE commands. 

Note: If a PERSISTENT RESERVE OUT command is received when a RESERVE is active for the drive, the command will be 
rejected with Reservation Conflict status. 

Parameter List Length must be 18h. If not, Check Condition status will be returned, with sense key of Illegal 
Request and additional sense code of Parameter List Length Error. 

8.14.1 Service Action 

The following service action codes are supported. 

Table 170 PERSISTENT RESERVE OUT, Service Action Code 


Code 

Name 

Description 

OOh 

Register 

Register a reservation key 

01 h 

Reserve 

Create a persistent reservation using a reservation key 

02 h 

Release 

Release a persistent reservation 

03 h 

Clear 

Clear all reservation keys and all persistent reservations 

04h 

Preempt 

Preempt persistent reservations from another Initiator 

05h 

Preempt and Abort 

Preempt persistent reservations from another Initiator and clear the 
task set for the preempted Initiator 

06h 

Register and Ignore existing key 

Register a reservation key 

07h-1 Fh 

Reserved 

Reserved 


HGST Hard Disk Drive OEM Specification 
170 





8.14.2 Type 

The Type field specifies the characteristics of the persistent reservation being established for all customer data 
sectors. The table below describes the supported types and how read and write commands are handled for each 
reservation type. 

Table 171 PERSISTENT RESERVE OUT, Type Code 


Code 

Name 

Description 

Oh 

Reserved 

Reserved 

1h 

Write Exclusive 

Reads Shared: Any initiator may execute commands that transfer from the media. 
Writes Exclusive: Only the initiator with the reservation may execute commands 
that transfer data to the media; Reservation Conflict status will be returned to other 
initiators. 

2h 

Reserved 

Reserved 

3h 

Exclusive Access 

Reads Exclusive: Only the initiator with the reservation may execute commands that 
transfer data from the media; Reservation Conflict status will be returned to other 
initiators. 

Writes Exclusive: Only the initiator with the reservation may execute commands 
that transfer data to the media; Reservation Conflict status will be returned to other 
initiators. 

4h 

Reserved 

Reserved 

5h 

Write Exclusive 
Registrants Only 

Reads Shard: Any initiator may execute commands that transfer from media. 

Writes Exclusive: Only registered initiators may execute commands that transfer 
data to the media; Reservation Conflict status will be returned to other initiators. 

6h 

Exclusive Access 
Registrants Only 

Reads Exclusive: Only registered initiators may execute commands that transfer 
data from the media; Reservation Conflict status will be returned to other initiators. 
Writes Exclusive: Only registered initiators may execute commands that transfer 
data to the media; Reservation Conflict status will be returned to other initiators. 

7h-Fh 

Reserved 

Reserved 


The RESPONSE frame is sent by the Drive to the Initiator (in bound data) or by the Initiator to the Drive (out bound 
data). 
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8.14.3 Parameter list 

The Parameter List required to perform the PERSISTENT RERSERVE OUT command is defined in the table below. 
All fields must be sent on all PERSISTENT RESERVE OUT commands, even if the field is not required for the 
specified service action. 


Table 172 Parameter List 


Byte 

Bit 

7 6 5 4 3 2 1 0 

0-7 

(MSB) 

Reservation Key 

(LSB) 

8-15 

(MSB) 

Service Action Reservation Key 

(LSB) 

16-19 

(MSB) 

Reserved = 0 

(LSB) 

20 

Reserved = 0 SPEC_I_P ALL_TG_PT Reserved = 0 APTPL 

21-23 

Reserved = 0 


Reservation Key contains an 8-byte value provided by the initiator, and identifies the initiator that issued the 
PERSISTENT RESERVE OUT command. The Reservation Key must match the registered reservation key for the 
initiator for all service actions except REGISTER and REGISTER AND IGNORE EXISTING KEY. 

Service Action Reservation Key contents vary based on the service action. For REGISTER and REGISTER AND 
IGNORE EXISTING KEY, the Service Action Reservation Key must contain the new reservation key to be registered. 
For PREEMPT and PREEMPT AND ABORT, the field contains the reservation key of the persistent reservation that 
is being preempted. This field is ignored for all other service actions. 

If the Specify Initiator Ports (SPEC_I_PT) bit is set to zero, the drive shall apply the registration only to the l_T nexus 
that sent the PERSISTENT RESERVE OUT command. If the SPEC_I_PT bit is set to one for any service action 
except the REGISTER service action, then the command shall be terminated with CHECK CONDITION status, with 
the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN PARAMETER 
LIST. If the SPEC_I_PT bit is set to one for the REGISTER service action, the additional parameter data (see table 
XXX) shall include a list of transport IDs and the drive shall also apply the registration to the l_T nexus for each 
initiator port specified by a Transport ID. If a registration fails for any initiator port (e.g., if the logical unit does not 
have enough resources available to hold the registration information), no registrations shall be made, and the 
command shall be terminated with CHECK CONDITION status. 

For Transport IDs, 

The All Target Ports (ALL_TG_PT) bit is valid only for the REGISTER service action and the REGISTER AND 
IGNORE EXISTING KEY service action, and shall be ignored for all other service actions. Support for the ALL_TG_PT 
bit is optional. If the drive receives a REGISTER service action or a REGISTER AND IGNORE EXISTING KEY service 
action with the ALL_TG_PT bit set to one, it shall create the specified registration on all target ports in the SCSI target 
device known to the drive (i.e., as if the same registration request had been received individually through each target 
port). If the drive receives a REGISTER service action ora REGISTER AND IGNORE EXISTING KEY service action 
with the ALL_TG_PT bit set to zero, it shall apply the registration only to the target port through which the 
PERSISTENT RESERVE OUT command was received. APTPL (Activate Persist Through Power Loss) bit is valid 
only for REGISTER and REGISTER AND IGNORE EXISTING KEY, and is ignored for all other service actions. If 
the last valid APTPL bit value received is zero, power loss will cause all persistent reservations to be released, and 
all reservation keys to be removed. If the last valid APTPL bit value received is one, any persistent reservation and 
all reservation keys for all initiators will be retained across power cycles. 

The RESPONSE frame is sent by the Drive to the Initiator (in bound data) or by the Initiator to the Drive (out bound 
data). 
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8.14.4 Summary 

Table 173 PERSISTENT RESERVE OUT, Service Action, Parameters 


Service Action 

Parameters 

Generation 

counter 

Scope 

Type 

Rsv Key 

SvcAct 

RsvKey 

S-spec 

addr 

Extent 

length 

APTPL 

(0) Register 

ignore 

verify 

save 

ignore 

ignore 

apply 

+ 1 

(1) Reserve 

apply 

verify 

ignore 

ignore 

ignore 

ignore 


(2) Release 

apply 

verify 

ignore 

ignore 

ignore 

ignore 


(5) Preempt and Abort 

apply 

verify 

save 

Ignore 

ignore 

ignore 

+ 1 


8.14.4.1 Scope, Type 

The Scope and the Type are applied in the process for the Reserve, Release, and Preempted and Clear service 
action but they are ignored in the process for the Register service action because they are not used. 

8.14.4.2 Reservation Key 

The Reservation Key is verified in each service action process. If the Initiator that registered a key is different from 
the Initiator requesting PERSISTENT RESERVE OUT command, the drive returns a Reservation Conflict status. 

8.14.4.3 Service Action Reservation Key 

On Register service action, the drive saves the key specified in the Service Action Reservation Key field as a key of 
Initiator requesting PERSISTENT RESERVE OUT command. 

On Preempt and Clear service action, the reservation that has a key specified in the Service Action Reservation Key 
field is preempted. 

On other service actions, this field is ignored. 

8.14.4.4 APTPL 

The APTPL (Active Persist Through Power Loss) is valid only for the Register service action. The drive ignores the 
APTPL in other service actions. 

The following table shows the relationship between the last valid APTPL value and information held by the drive. 


Table 174 APTPL and information held by a drive 


Information held by the 
drive 

The last valid APTPL value 

0 

1 

Registration 

all keys are set to 0 

retained 

Persistent Reservation 

all are removed 

retained 

Generation counter 

set to 0 

set to 0 


8.14.4.5 Generation counter 

The drive increments the Generation counter when Register service action or Preempt and Clear service action 
complete successfully. 
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8.15 PRE-FETCH (34) 


Table 175 PRE-FETCH (34) 


Byte 

Bit 

7 6 

5 

4 3 2 

1 

0 

0 

Command Code = 34h 

1 

Reserved = 0 

Reserved = 0 

Immed = 0 

Obsolete 

2-5 

(MSB) 

Logical Block Address 

(LSB) 

6 

Reserved = 0 

7-8 

(MSB) 

Transfer Length 

(LSB) 

9 

vu = o 

Reserved = 0 

FLAG 

LINK 


The PRE-FETCH command requests the drive to transfer data to the cache. No data is transferred to the Initiator. 

• Transfer length field specifies the number of contiguous blocks of data that are to be transferred into the cache. 
A transfer length of zero indicates that blocks are to be transferred into the cache until the segment is filled or 
until the last block on the media. 

• Immed (Immediate) must be zero. An immediate bit of zero indicates that the status shall not be returned until 
the operation has completed. 

If the Immed bit is set to one, the drive returns a Check Condition status. The sense key shall be set to Illegal 
Request and the additional sense code shall be set to Invalid Field in CDB. 
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8.16 PRE-FETCH (90) 


Table 176 PRE-FETCH (90) 


Byte 

Bit 

7 

6 

5 

4 3 

2 

1 

0 

0 

Command Code = 90h 

1 

Reserved = 0 

Reserved = 0 

Immed = 0 

Reserved = 0 

2-9 

(MSB) 

Logical Block Address 
(LSB) 

10-13 

Transfer Length 

14 

Restricted 
For MMC-4 

Reserved = 0 

GROUP NUMBER = 0 

15 

VU = 0 

Reserved = 0 

FLAG 

LINK 


The PRE-FETCH command requests the drive to transfer data to the cache. No data is transferred to the Initiator. 

• Transfer length field specifies the number of contiguous blocks of data that are to be transferred into the cache. 
A transfer length of zero indicates that blocks are to be transferred into the cache until the segment is filled or 
until the last block on the media. 

• Immed (Immediate) must be zero. An immediate bit of zero indicates that the status shall not be returned until 
the operation has completed. 

If the Immed bit is set to one, the drive returns a Check Condition status. The sense key shall be set to Illegal 
Request and the additional sense code shall be set to Invalid Field in CDB6) - (08) 
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8.17 READ (6) - (08) 


Table 177 READ (6) - (08) 


Byte 

Bit 

7 6 

5 

4 3 2 

1 

0 

0 

Command Code = 08h 

1 

Reserved = 0 

(MSB) LBA 

2-3 

Logical Block Address 

(LSB) 

4 

Transfer Length 

5 

< 

c 

o 

Reserved = 0 

FLAG 

LINK 


The READ command requests the drive to transfer from the medium to the initiator the specified number of blocks 
(Transfer Length) starting at the specified Logical Block Address (LBA). 

• Logical block address field specifies the logical unit at which the READ operation shall begin. 

• Transfer length field specifies the number of blocks to be transferred. A value of zero implies 256 blocks are to 
be transferred. 

Note: Error recovery procedure (ERP) handles errors. The error recovery parameters specified by the MODE SELECT command 
control ERPs. If the drive is formatted with protection information, no protection information will be transmitted or checked. 
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8.18 READ (10) - (28) 


Table 178 READ (10) - (28) 


Byte 

Bit 

7 6 5 4 3 2 1 0 

0 

Command Code = 28h 

1 

RDPROTECT DPO FUA Rsvd=0 FUA_NV Obsolete 

2-5 

(MSB) 

Logical Block Address 

(LSB) 

6 

Reserved = 0 

7-8 

(MSB) 

Transfer Length 

(LSB) 

9 

VU = 0 Reserved = 0 FLAG LINK 


The READ (10) command requests the drive to transfer data to the Initiator. The larger LBA and Transfer Length 
fields permit greater quantities of data to be requested per command than with the READ command and are required 
to access the full LBA range of the larger capacity drives. 

• FUA_NV (Force Unit Access Non-Volatile Cache) may be set to 0 or 1, but is ignored since NV_SUP=0 in Inquiry 
Page 86h. 

• Transfer length The number of contiguous blocks to be transferred. If the transfer length is zero, the seek occurs, 
but no data is transferred. This condition is not considered an error. If read ahead is enabled, a read ahead is 
started after the seek completes. 

• DPO (Disable Page Out) bit of one indicates that the data accessed by this command is to be assigned the 
lowest priority for being written into or retained by the cache. A DPO bit of one overrides any retention priority 
specified in the Mode Select Page 8 Caching Parameters. A DPO bit of zero indicates the priority is determined 
by the retention priority. The Initiator should set the DPO bit when the blocks read by this command are not likely 
to be read again in the near future. 

• FUA (Force Unit Access) bit of one indicates that the data is read from the media and not from the cache. A FUA 
bit of zero allows the data to be read from either the media or the cache. 

• RDPROTECT defines the manner in which protection information read from disk shall be checked during 
processing of the command. Protection information is stored on disk, and may be transmitted to the drive's 
internal data buffer and to the initiator with the user data. If the drive is not formatted with protection information, 
RDPROTECT must be set to 000b, else Check Condition status will be returned with sense key of Illegal 
Request and additional sense code of Invalid Field in CDB. 

RDPROTECT=000b 

- Protection information is not transmitted to the initiator and is not checked. 

RDPROTECT=001b 

- Protection information is transmitted to the initiator with the user data 

- Logical Block Guard is checked 

- Logical Block Application Tag is checked (applies to READ(32) command only) 

- Logical Block Reference Tag is checked 
RDPROTECT=010b 

Protection information is transmitted to the initiator with the user data 
Logical Block Guard is not checked 

Logical Block Application Tag is checked (applies to READ(32) command only) 

Logical Block Reference Tag is checked 
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RDPROTECT=011b 

Protection information is transmitted to the initiator with the user data 
Logical Block Guard is not checked 
Logical Block Application Tag is not checked 
Logical Block Reference Tag is not checked 
RDPROTECT=100b 

Protection information is transmitted to the initiator with the user data 
Logical Block Guard is checked 
Logical Block Application Tag is not checked 
Logical Block Reference Tag is not checked 
RDPROTECT=101 b, 110b, 111 b 

These values are reserved. Check Condition status will be returned with sense key of Illegal Request and 
additional sense code of Invalid Field in CDB. 

If a check of the protection information fails, Check Condition status will be returned with sense key of Aborted 
Command and additional sense code indicating which protection field check failed. 

Refer to the ANSI T10 standards for additional details of protection information. 

If the transfer length is zero, no data is transferred. The CDB is validated and protocol checked and, if no problems 
are found, Good status is returned immediately. This condition is not considered an error. 
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8.19 READ (12) - (A8) 


Table 179 READ (12) - (A8) 


Byte 

Bit 

7 6 

5 

4 

3 

2 

1 

0 

0 

Command Code = A8h 

1 

RDPROTECT 

DPO 

FUA 

Rsvd = 0 

FUANV 

Rsvd = 0 

2-5 

(MSB) 

Logical Block Address 

(LSB) 

6-9 

(MSB) 

Transfer Length 

(LSB) 

10 

Reserved = 0 

11 

VU = 0 

Reserved = 0 

FLAG 

LINK 


The READ (12) command causes the drive to transfer data to the initiator. See the READ(IO) description for the 
definitions of the fields in this command. 
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8.20 READ (16) - (88) 


Table 180 READ (16) - (88) 


Byte 

Bit 

7 

6 

5 

4 

3 

2 

1 

0 

0 

Command Code = 88h 

1 

RDPROTECT 

DPO 

FUA 

Rsvd=0 

FUANV 

Rsvd=0 

2-9 

(MSB) 

Logical Block Address 

(LSB) 

10-13 

(MSB) 

Transfer Length 

(LSB) 

14 

Restricted For 
MMC-4 

Reserved = 0 

GROUP NUMBER =0 

15 

VU = 0 

Reserved = 0 

FLAG 

LINK 


The READ (16) command causes the drive to transfer data to the initiator. See the READ (10) description for the 
definitions of the fields in this command. 
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8.21 

READ (32) - 

(7F/09) 


Table 181 

READ (32) - (7F/09) 



Byte 

Bit 

1 7 1 6 1 

5 4 3 2 1 ! 

0 1 

0 

Command Code = 7Fh 

1 

| VU = 0 

Reserved = 0 FLAG 

LINK 

2-5 

Reserved = 0 

6 

Reserved = 0 

Group Number = 0 


7 

Additional CDB Length = 18h 

8-9 

Service Action = 0009h 

10 

RDPROTECT 

DPO FUA Rsvd=0 FUA_NV 

Rsvd=0 

11 

Reserved = 0 

12-19 

(MSB) 

Logical Block Address 

(LSB) 

20-23 

(MSB) 

1 

Expected Initial Logical Block Reference Tag 

(LSB) 

24-25 

(MSB) 

Logical Block Application Tag 

(LSB) 

26-27 

(MSB) 

Logical Block Application Tag Mask 

(LSB) 

28-31 

(MSB) 

Transfer Length 

(LSB) 


The READ command requests that the drive transfer data from disk to the initiator. Each logical block transferred 
includes user data and may include protection information, based on the RDPROTECT field and the drive format. 

If the drive is formatted with type 2 protection (PROT_EN=1 and P_TYPE=001b in the READ CAPACITY (16) 
parameter data), then this command will be processed normally. Any other protection types will result in Check 
Condition status to be returned with sense key of Illegal Request and additional sense code of Invalid Command 
Operation Code 

The Expected Initial Logical Block Reference Tag field contains the value of the Logical Block Reference Tag field 
expected in the protection information of the first logical block accessed by the command. 

If the ATO bit is set to one in Mode Page OAh, the Logical Block Application Tag Mask field contains a value that is a 
bit mask for enabling the checking of the Logical Block Application Tag field in the protection information for each 
logical block accessed by the command. A Logical Block Application Tag Mask bit set to one enables the checking 
of the corresponding bit of the Expected Logical Block Application Tag field with the corresponding bit of the Logical 
Block Application Tag field in the protection information. 

If the ATO bit is set to zero, the Logical Block Application Tag Mask field and the Expected Logical Block Application 
Tag field are ignored. 
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8.22 READ BUFFER (3C) 


Table 182 READ BUFFER (3C) 


Byte 

Bit 

7 6 

5 

4 3 2 

1 

0 

0 

Command Code = 3Ch 

1 

Reserved = 0 

Mode 

2 

Buffer ID = 0 

3-5 

(MSB) 

Buffer Offset 

(LSB) 

6-8 

(MSB) 

Allocation Length 

(LSB) 

9 

VU = 0 

Reserved = 0 

FLAG 

LINK 


The READ BUFFER command is used in conjunction with the WRITE BUFFER command as a diagnostic function 
for testing the memory of the drive and the SCSI bus integrity. This command does not alter the medium. 

The function of this command and the meaning of fields within the command descriptor block depend on the contents 
of the mode field. 

Table 183 Mode 


MOD 

Description 

00000 

Read Combined Header and Data 

00010 

Read Data 

00011 

Descriptor 

01010 

Read Data from Echo Buffer 

01011 

Echo Buffer Descriptor 

11010 

Enable Expander Communications Protocol and Echo Buffer 

All others 

Not supported 
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8.22.1 Combined Header And Data (Mode 00000b) 

In this mode a 4-byte header followed by data bytes is returned to the Initiator during the DATA IN phase. The Buffer 
ID and the buffer offset field are reserved. 

The drive terminates the DATA IN phase when allocation length bytes of header plus data have been transferred or 
when the header and all available data have been transferred to the Initiator, whichever is less. 

The 4-byte READ BUFFER header (see figure below) is followed by data bytes from the data buffer of the drive. 


Table 184 Read Buffer Header 


Byte 

Bit 

7 6 5 4 3 2 1 

0 

RSVD = 0 

1-3 

(MSB) 

Buffer Capacity 

(LSB) 


The buffer capacity specifies the total number of data bytes that are available in the data buffer of the drive. This 
number is not reduced to reflect the allocation length nor is it reduced to reflect the actual number of bytes written 
using the WRITE BUFFER command. 

Following the READ BUFFER header the drive will transfer data from its data buffer. 

8.22.2 Read Data (Mode 00010b) 

In this mode, the DATA IN phase contains buffer data. 

• Buffer ID field must be set to zero, indicating the data transfer buffer. If another value is specified, the results 
may be unpredictable. 

• Buffer Offset specifies the offset of the memory space specified by the Buffer ID. The Initiator should conform 
to the offset boundary requirements returned in the READ BUFFER descriptor. If the value exceeds the buffer 
specified, the command is terminated with Check Condition status. The drive shall set sense key to Illegal 
Request and additional sense code to Illegal Field in CDB. 

• Allocation Length The drive terminates the DATA IN phase when allocation length bytes of data have been 
transferred or when the header and all available data have been transferred to the Initiator, whichever is less. 
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8.22.3 Descriptor (Mode 00011b) 

In this mode, a maximum of four bytes of READ BUFFER descriptor information are returned. The drive returns the 
descriptor information for the buffer specified by the Buffer ID. 

• Buffer ID field should normally be set to zero, indicating the drive data transfer buffer. If any other value is 
specified, the results may be unpredictable. 

• Buffer Offset field is reserved. 

• Allocation Length should be set to four or greater. The drive transfers the allocation length or four bytes of 
READ BUFFER descriptor, whichever is less. The allocation length of zero indicates no data is transferred. The 
allocation length of greater than zero and less than four (size of the Descriptor) is an invalid request and will 
cause the command to be terminated with Check Condition status. The drive shall set sense key to Illegal 
Request and additional sense code to Illegal Field in CDB. 

The READ BUFFER descriptor is defined in the figure below. 


Table 185 Read Buffer Description 


Byte 

Bit 

7 6 5 4 3 2 1 

0 

Offset Boundary = 0x09 

1-3 

(MSB) 

Buffer Capacity 

(LSB) 


The value contained in the Buffer Offset field of subsequent WRITE BUFFER and READ BUFFER commands should 
be a multiple of two to the power of the offset boundary. The offset boundary is always set to nine, which indicates 
Sector Boundaries. 

8.22.4 Read Data from Echo Buffer (Mode 01010b) 

In this mode the drive transfers data from the echo buffer. The echo buffer will transfer the same data as when the 
WRITE BUFFER command was issued with the mode field set to echo buffer. 

WRITE BUFFER command with the mode field set to echo buffer should be sent prior to the READ BUFFER 
command; otherwise the READ BUFFER command will be terminated with Check Condition status and Illegal 
Request. 

In this mode Read Buffer transfers the specified amount of data or the amount previously written with a Write Buffer 
using mode 1010b from the echo buffer, whichever is less. 

Issuing a Read Buffer mode 1010b before a Write Buffer mode 1010b will cause indeterminate data to be returned. 
The most significant two bytes of the Allocation Length are ignored. The specified amount of data transferred should 
not be larger than the echo buffer capacity. The echo buffer capacity may be determined by using Read Buffer mode 
1011b. Any additional data transferred over and above the echo buffer capacity is regarded as indeterminate. 

The Buffer ID and Buffer Offset fields are ignored in this mode. 

Note: The echo buffer is a separate buffer from the data buffer used with other read buffer modes. It is intended to be used for 
domain validation purposes. 
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8.22.5 Echo Buffer Descriptor (Mode 01011b) 

In this mode, a maximum of four bytes of Read Buffer Descriptor information is returned. The drive returns the 
descriptor information for the echo buffer. The Buffer Offset field is reserved in this mode and must be zero. The drive 
transfers the lesser of the allocation length or four bytes of following Echo Buffer Descriptor. 

Table 186 Echo Buffer Descriptor 


Byte 

Bit 

7 6 5 4 

3 2 1 

0 

0 

Reserved = 0 

EBOS=0 

1 

Reserved = 0 

2 

Reserved = 0 

(MSB) Buffer Capacity 

3 

Buffer Capacity (LSB) 


• EBOS (Echo Buffer Overwritten Supported) bit of zero indicates that the echo buffer is shared by all Initiators. 

• Buffer Capacity field returns the size of the echo buffer in byte aligned to a 4-byte boundary. 

8.22.6 Expander Communications and Echo Buffer (Mode 11010b) 

Receipt of a READ BUFFER command with this mode (11010b) causes a communicative expander to enter the 
expanded communication protocol mode. SCSI target devices that receive a READ BUFFER command with this 
mode shall process it as if it were a READ BUFFER command with mode 01010b (see 17.17.4 Read Data from Echo 
Buffer). 
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8.23 READ CAPACITY (10) - (25) 


Table 187 READ CAPACITY (10) - (25) 


Byte 

Bit 

7 6 

5 

4 3 2 

1 

0 

0 

Command Code = 25h 

1 

Reserved = 0 

Reserved = 0 

Obsolete 

2-5 

Obsolete 

6-7 

Reserved = 0 

8 

Reserved = 0 

Obsolete 

9 

VU = 0 

Reserved = 0 

FLAG 

LINK 


The READ CAPACITY command returns information regarding the capacity of the drive. 


8.23.1 Returned Data Format 

The data returned to the Initiator in response to the READ CAPACITY command is described here. The data is 
returned in the DATA IN phase. 


Table 188 Format of READ CAPACITY command reply 


Byte 

Bit 

6 7 5 4 3 2 1 0 

0-3 

(MSB) 

Maximum Logical Block Address 

(LSB) 

4-7 

(MSB) 

Block Length 

(LSB) 


• Block Length specifies the length in bytes of each block of user data (not including protection information). 
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8.24 READ CAPACITY (16) (9E/10) 


Table 189 Read Capacity (16) (9E/10) 


Byte 

Bit 

7 6 5 4 3 21 0 

0 

Command Code = 9Eh 

1 

Reserved = 0 Service Action = 10h 

2-9 

Obsolete 

10-13 

(MSB) 

Allocation Length 

(LSB) 

14 

Reserved = 0 

Obsolete 

15 

VU = 0 Reserved = 0 FLAG 

Link 


The READ CAPACITY (16) (9E/10) command returns information regarding the capacity of the drive. This command 
is processed like the standard READ CAPACITY (25) command. 

8.24.1 Returned Data Format 

The following data is returned to the initiator in the DATA OUT phase. 

Table 190 Returned Data Format 


Byte 

Bit 

7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 

0-7 

(MSB) 

Maximum Logical Address 

(LSB) 

8-11 

(MSB) 

Block Length 

(LSB) 

12 

Reserved = 0 

P-Type Prot-EN 

13 

PlExponent 

Logical Blocks per Physical Block Exponent 

14-31 

Reserved = 0 


The protection type (P_TYPE) field and the protection enable (PROT_EN) bit indicate the drive's current type of 
protection. 

Table 191 Protection Type (P_TYPE) field 


Prot-EN 

P-Type 

Description 

0b 

000b 

The drive is formatted to type 0 protection 

1b 

000b 

The drive is formatted to type 1 protection 

1b 

001b 

The drive is formatted to type 2 protection 


Table 192 Logical Blocks per Physical Block Exponent field 


Code 

Description 

0 

One or more physical blocks per logical block 

n > 0 

2 n logical blocks per physical block 


The number of physical blocks per logical block is not reported. 
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8.25 READ DEFECT DATA (37) 


Table 193 READ DEFECT DATA (37) 


Byte 

Bit 

7 6 5 4 3 21 0 

0 

Command Code = 37h 

1 

Reserved = 0 

Reserved = 0 0 

2 

Reserved = 0 

Plist Glist Defect List Format 

3-6 

Reserved = 0 

7-8 

(MSB) 

Allocation Length 

(LSB) 

9 

VU = 0 Reserved = 0 FLAG LINK 


The READ DEFECT DATA command requests that the Target transfer the medium defect data to the Initiator. 

If the Target is unable to access any medium defect data it will return a Check Condition status with the appropriate 
sense key. The sense key will be set to either Medium Error (03h) if a medium error occurred or No Sense (OOh) if 
the list does not exist and the additional sense code will be set to Defect List Error (19h). 

• Plist bit set to one indicates that the Target returns the Plist. A Plist bit of zero indicates that the Target shall not 
return the Plist of defects. 

• Glist bit set to one indicates that the Target returns the Glist. A Glist bit of zero indicates that the Target shall 
not return the Glist. 

Note: With both bits set to one Plist and Glist the Target will return both the primary and grown defect lists. With both 
bits set to zero, the Target will return only a 4-byte Defect List Header. 

• Defect List format field is used by the Initiator to indicate the preferred format for the defect list. 

The Defect List Format of '100 (Bytes from Index Format)' and '101 (Physical Sector Format)' are supported. If 
the requested format is not supported by the drive, it will return the defect list in its default format '10T and then 
terminate the command with Check Condition status. The sense key will be set to Recovered Error (01 h) and 
the additional sense code will be set to Defect List Not Found (1 Ch). 

The drive sends defect list (Defect Descriptors) in an 8-byte Absolute Block Address (ABA) format that follows a four 
byte Defect List Header. 

The Target will transfer all of the Read Defect Data up to the number of bytes allocated by the Initiator. 


Table 194 Defect List Format 


Preferred Defect List Format 

Returned Defect List Format 

Block (000b) 

Physical Sector 

Bytes from Index (100b) 

Bytes from Index 

Physical Sector (101b) 

Physical Sector 

Vendor Unique (110b) 

Physical Sector 

Reserved (001b) 


Reserved (010b) 


Reserved (011b) 


Reserved (111b) 



Note: The drive will terminate the Data in phase when the Allocation Length has been transferred or when all available 
Defect Data has been transferred to the Initiator, whichever is less. 

The Read Defect Data contains a 4-byte header followed by zero or more defect descriptors. 
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8.25.1 Defect List Header 


Table 195 Defect List Header 



Bit 

Byte 

765 

1 4 1 3 1 

2 1 1 1 0 1 


Defect List Header 

0 

Reserved = 0 

1 

Reserved = 0 

Plist Glist 

Defect List Format 

2-3 

(MSB) 

Defect List length 

(LSB) 


8.25.2 Defect List Descriptor 


Table 196 Defect List Descriptor 


Byte 

Bit 

7 | 6 P5 1 4 1 3 | 2 | 1 | 0 

Defect List Header 

0-7 

Defect Descriptor 0 

8n - (8n+7) 

Defect Descriptor n 


8.25.3 Bytes from Index Format (100b) 


Table 197 Defect Descriptors of Bytes from Index Format 


Byte 

Defect Descriptors 

0-2 

(MSB) 

Cylinder Number of Defect 

(LSB) 

3 

Head Number of Defect 

4-7 

(MSB) 

Defect Bytes from Index 

(LSB) 


Defect Bytes from Index is gotten using the following equation: 
Bytes from Index = (Physical Sector Number) * N 
Where: N = Bytes per sector 
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8.25.4 Physical Sector Format (101b) 


Table 198 Defect Descriptors of Physical Sector Format 


Byte 

Defect Descriptors 

0-2 

(MSB) 

Cylinder Number of Defect 

(LSB) 

3 

Head Number of Defect 

4-7 

(MSB) 

Defective Sector Number 

(LSB) 


The Defect List Format field specifies the format of the defect list data returned by the Target. 

The Defect List Length field specifies the length in bytes of the defect descriptors that follow. The Defect List Length 
is equal to eight times the number of defect descriptors. 

Normally the Target will set the Defect List Length field to the amount of space needed to contain the entire defect 
list. However, the Target is capable of building a defect list with a length such that the entire list cannot be transferred 
using the maximum allocation length. If the defect list grows beyond 8191 entries, the defect data cannot be 
transferred with an allocation length of OFFFFh. The Target will transfer a partial defect list and return Check Condition 
status with the sense key set to Recovered Error and the additional sense code set to Partial Defect List Transferred. 
The defect list length will be set to 0FFF8h, indicating the maximum number of defect descriptors that can be 
transferred. Defects beyond this number cannot be read by the Initiator. 
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8.26 READ DEFECT DATA (B7) 


Table 199 READ DEFECT DATA (B7) 


Byte 

Bit 

765 

1 4 1 3 1 

2 1 1 1 0 1 

0 

Command Code = B7h 

1 

Reserved = 0 

Plist Glist 

Defect List Format 

2-5 

Reserved = 0 

6-9 

(MSB) 

Allocation Length 

(LSB) 

10 

Reserved = 0 

11 

VU = 0 

Reserved = 0 

FLAG LINK 


(See Section 8.25 “READ DEFECT DATA (37)”) 

8.26.1 Defect List Header 


Table 200 Unit Defect List Header 



Bit 

Byte 

765 

1 4 1 3 1 

2 1 1 1 0 1 


Defect List Header 

0 

Reserved = 0 

1 

Reserved = 0 

Plist Glist 

Defect List Format 

2-3 

Reserved = 0 

4-7 

(MSB) 

Defect List length 

_(LSB) 


(See Defect List Header for Read Defect Data (37) in Section 8.25.1 "Defect List Header".) 


8.26.2 Defect List Descriptor 


Table 201 Defect List Descriptor 


Byte 

Bit 

7 6 5 4 3 21 0 

Defect List Header 

0-7 

Defect Descriptor 0 

8n - (8n+7) 

Defect Descriptor n 


(See Defect List Descriptor for Read Defect Data (37) in Section 0 "Defect List Descriptor".) 
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8.26.3 Bytes from Index Format (100b) 


Table 202 Defect Descriptors of Bytes from Index Format 


Byte 

Defect Descriptors 

0-2 

(MSB) 

Cylinder Number of Defect 

(LSB) 

3 

Head Number of Defect 

4-7 

(MSB) 

Defect Bytes from Index 

(LSB) 


Defect Bytes from Index is derived using the following equation: 
Bytes from Index = (Physical Sector Number) + N 
where N = Bytes per sector. 


8.26.4 Physical Sector Format (101b) 


Table 203 Defect Descriptors of Physical Sector Format 


Byte 

Defect Descriptors 

0-2 

(MSB) 

Cylinder Number of Defect 

(LSB) 

3 

Head Number of Defect 

4-7 

(MSB) 

Defective Sector Number 

(LSB) 
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8.27 READ LONG (3E) 


Table 204 READ LONG (3E) 


Byte 

Bit 

7 6 

5 4 3 2 

1 

0 

0 

Command Code = 3Eh 

1 

Reserved = 0 

Correct = 0 

Obsolete 

2-5 

(MSB) 

Logical Block Address 

(LSB) 

6 

Reserved = 0 

7-8 

(MSB) 

Byte Transfer Length 

(LSB) 

9 

VU = 0 

Reserved = 0 

FLAG 

LINK 


The READ LONG command requests the drive to transfer one block of data to the Initiator. The transfer data includes 
data and MEDC field data. 

• Correct transferred bit of zero causes correction to be attempted, data will be returned without reporting media 
errors regardless of the drives ability to successfully make corrections. When this bit is set the drive will return 
media errors if correction is not successful. 

• Logical Block Address field specifies the logical block at which the read operation shall occur. 

• Byte Transfer Length field must specify exactly the number of bytes of data that are available for transfer. If a 
non-zero byte transfer length does not match the available data length, the Target terminates the command with 
Check Condition status, the sense key is set to Illegal Request , and an additional sense code set to Invalid 
Field in CDB. The valid and ILI bits are set to one and the information field is set to the difference of the requested 
length minus the actual length in bytes. Negative values are indicated by two's complement notation. 

The transfer length is calculated as follows: 

transfer length = logical block size + 18 

The data read by this command is neither read from nor retained in the cache. Data returned by this command cannot 
be corrupted and transferred on a subsequent WRITE LONG command to create recoverable media errors. 
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8.28 READ LONG (9E) 


Table 205 READ LONG (9E) 


Byte 

Bit 

7 6 

5 

4 3 2 

1 

0 

0 

Command Code = 9Eh 

1 

Reserved = 0 

Service Action (11 h) 

2-9 

(MSB) 

Logical Block Address 

(LSB) 

10-11 

Reserved = 0 

12-13 

(MSB) 

Byte Transfer Length 

(LSB) 

14 

Reserved = 0 

PBLOCK 

CORRCT 

15 

vu = o 

Reserved = 0 

FLAG 

LINK 


The READ LONG command requests the drive to transfer one block of data to the Initiator. The transfer data includes 
data and MEDC field data. 

• Correct transferred bit of zero causes correction to be attempted, data will be returned without reporting media 
errors regardless of the drives ability to successfully make corrections. When this bit is set the drive will return 
media errors if correction is not successful. 

• Logical Block Address field specifies the logical block at which the read operation shall occur. 

• Byte Transfer Length field must specify exactly the number of bytes of data that are available for transfer. If a 
non-zero byte transfer length does not match the available data length, the Target terminates the command with 
Check Condition status, the sense key is set to Illegal Request, and an additional sense code set to Invalid 
Field in CDB. The valid and ILI bits are set to one and the information field is set to the difference of the requested 
length minus the actual length in bytes. Negative values are indicated by two's complement notation. 

The transfer length is calculated as follows: 

transfer length = logical block size + 18 

The data read by this command is neither read from nor retained in the cache. Data returned by this command can 
not be corrupted and transferred on a subsequent WRITE LONG command to create recoverable media errors. 
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8.29 REASSIGN BLOCKS (07) (Not supported) 


Table 206 REASSIGN BLOCKS (07) 


^Byte^ 

__ Bit 

| 4 | 3 | 2 

0 

^^Comman^JS©dS^07h 

1 

ReserveeF^T) LONGLBA Reserved = 0 

2-4 

Reserved = 0 

VU = 0 Reserved = 0 FLAG 


Cold storage product does not support REASSIGN BLOCKS command. When the drive receives REASSIGN 
BLOCKS command from the host, the drive will abort the command. 

The REASSIGN BLOCKS command requests the drive to reassign a logical block to an available spare. The 
REASSIGN BLOCKS command attempts to allocate spare blocks on a spare track. The LBA is transferred to the 
drive during the DATA OUT phase. One to four blocks may be specified for relocation per REASSIGN BLOCKS 
command. 

Reassignment is complete upon the completion of the REASSIGN BLOCKS command. At this time, the defective 
logical block address has been added to the Glist. 

All data is preserved during a reassign command except for the target LBA data. The Mode Page Oh DRRT (Disable 
Restore Reassign Target) bit determines if the reassign blocks command will attempt to recover the Target LBA data. 
If the Target cannot recover the data at the Target LBA then the Initiator will have to restore the data after the 
REASSIGN BLOCKS command completes successfully. 

If the reassignment begins to move data and is interrupted or fails to complete successfully, the Target enters a 
degraded mode of operation. In this mode data can be read but writing to the drive is prohibited. 

Upon successful completion of this command, the location of the physical sectors reassigned during the command 
are added to the Glist. The reassigned sectors are marked defective and cannot be accessed again until after a 
format operation discards the Glist. 

• LONGLBA bit of zero indicates that LBAs in the provided defect list are 4-bytes. A LONGLBA bit of one indicates 
that the LBAs in the provided defect list are 8-bytes 

Following is the format of the data sent by the Initiator during the DATA OUT phase. 


Table 207 Format of Reassign Blocks Parameter List data 


Byte 

Bit 

7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 

0-1 

Reserved = 0 

2-3 

(MSB) 

Defect List Length 

(LSB) 

4-n 

Defect LBA List 


• Defect List Length is the total number of bytes in the Defective LBA List (n - 4). 

• Defective LBA List is a list of zero to four Logical Block Addresses to be reassigned. The number of bytes 
describing each LBA is determined by the LONGLBA field in the command block. 
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8.30 RECEIVE DIAGNOSTICS RESULTS (1C) 


Table 208 RECEIVE DIAGNOSTIC RESULTS (1C) 


Byte 

Bit 

7 6 5 4 3 2 

10 

0 

Command Code = ICh 

1 

Reserved = 0 Reserved = 0 

PCV 

2 

Page Code 

3 

(MSB) 


4 

Allocation Length 

(LSB) 

5 

VU = 0 Reserved = 0 

FLAG LINK 


The RECEIVE DIAGNOSTIC RESULTS command requests that analysis data requested by a SEND DIAGNOSTIC 
command be sent to the Initiator. 

• PCV (Page Code Valid) bit of zero indicates that the most recent SEND DIAGNOSTIC command shall define 
the data returned by this command. PCV bit of one indicates that the contents of the Page Code field shall define 
the data returned by this command. 

• Allocation Length specifies the amount of data to be returned to the Initiator. This value may be zero and this 
is not considered an error. The Target terminates the Data in phase when all available data has been transferred 
or when the number of bytes transferred equals the Parameter List Length. 

8.30.1 Receive Diagnostic Results Page 0 


This page contains a list of supported pages. 
Table 209 Receive Diagnostic Results page 0 


Byte 

Bit 

7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 

0 

Page Code = 0 

1 

Reserved = 0 

2-3 

Page Length = 04h 

4 

(Supported Pages) Page = Oh 

5 

CJTPAT page = 3Fh 

6 

Translate address page = 40h 

7 

Rebuild Assist support page = 42h 


The supported diagnostic page returns a list of supported pages in ascending order. 
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8.30.2 Receive Diagnostic Results Page 40 

Using the SEND DIAGNOSTIC command, an address in either physical or logical format is supplied to the drive. This 
page is then used to retrieve the address translated into the other format. 

Table 210 Receive Diagnostic Results page 40 


Byte 

Bit 

7 1 6 | 5 | 4 | 3 | 2 | 1 | 0 

0 

Page Code = 40h 

1 

Reserved = 0 

2-3 

Page Length 

4 

Reserved = 0 

Supplied Format 

5 

RA ALTS ALTT Reserved=0 

Translate Format 

6-13 

Translated Address 


Page Length is set to 02h if the address is in a Reserved Area (RA =1). Otherwise, Page Length is set to OAh. 
Supplied Format is the value supplied by the SEND DIAGNOSTIC command; it may be 1 of the 3 following 
values: 

- 000b Short Block format 

- 011b Long Block format 

- 100b Bytes From Index format 

- 101b Physical Sector format 

Translate Format is the value supplied by the SEND DIAGNOSTIC command and specifies the format in which 
the address has been translated into List. If the Supplied Format is the Short Block or Long Block format, the 
Translate Format must be either Bytes from Index or Physical Sector format. If the Supplied Format is the Bytes 
from Index or Physical Sector format, the Translate Format must be Long Block format. Otherwise the Target 
will terminate the command with Check Condition status. 

RA (Reserved Area) is set to one if the translated block is an inaccessible sector, which could reflect a defect, 
an unused sector on a spare cylinder, or a sector beyond the Maximum Customer LBA. 

ALTS (Alternate Sector) is set to one if the translated block is a sector in a spare cylinder that points to a 
reassigned customer sector. 

ALTT (Alternate Track) is not used. 

Translated Address contains the address in the Translate Format. For a physical format it is as follows: 


Table 211 Translated address 


Byte 

Bit 

7 6 5 4 3 21 0 

6-8 

Cylinder Number 

9 

Head Number 

10-13 

Sector Number or Bytes from Index 
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8.31 RELEASE (17) 


Table 212 RELEASE (17) 


Byte 

Bit 

7 6 

5 

4 

3 2 

1 

0 

0 

Command Code = 17h 

1 

Reserved = 0 

3rdPty=0 

3rd Party ID 

Ext=0 

2 

Reservation Identification 

3-4 

Reserved = 0 

5 

< 

c 

o 

Reserved = 0 

FLAG 

LINK 


The RELEASE command is used to release a LUN previously reserved. It is not an error for an Initiator to release 
a LUN that is not currently active. The drive returns Good status without altering the reservation. 

• 3rdPty must be 0. Third Party reservations are not supported. If the 3rdPty bit is not zero, Check Condition 
status is returned with a sense key of Illegal Request and additional sense code of Invalid Field in CDB. 

• 3rd Party ID is ignored. 

• Extents must be 0. Extension is not supported by the drive. 

• Reservation Identification field is ignored. 
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8.32 RELEASE (57) 


Table 213 RELEASE (57) 


Byte 

Bit 

7 6 

5 

4 

3 2 

1 

0 

0 

Command Code = 57h 

1 

Reserved = 0 

3rdPty=0 

Reserved = 0 

Ext = 0 

2 

Reservation Identification 

3 

3rd Party Device ID 

4-8 

Reserved = 0 

9 

vu = o 

Reserved = 0 

FLAG 

LINK 


The RELEASE command is used to release a LUN previously reserved. It is not an error for an Initiator to release 
a LUN that is not currently active. The drive returns Good status without altering the reservation. 

• 3rdPty must be 0. Third Party reservations are not supported. If the 3rdPty bit is not zero, Check Condition 
status is returned with a sense key of Illegal Request and additional sense code of Invalid Field in CDB. 

• 3rd Party ID is ignored. 

• Extent must be 0. Extension is not supported by the drive. 

• Reservation Identification field is ignored. 
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8.33 REPORT DEVICE IDENTIFIER (A3/05) 


Table 214 REPORT DEVICE IDENTIFIER (A3/0S) 


Byte 

Bit 

7 6 5 4 3 21 0 

0 

Command Code = A3h 

1 

Reserved = 0 Service Action = 05h 

2 

Reserved = 0 

3 

Reserved = 0 

4-5 

(MSB) 

LUN=0 

(LSB) 

6-9 

(MSB) 

Allocation Length 

(LSB) 

10 

Reserved = 0 

11 

VU = 0 Reserved = 0 FLAG LINK 


The REPORT DEVICE IDENTIFIER command requests that the drive send device identification information to the 
application client. 

The LUN contains the logical unit number parameter. This parameter is expected to be zero. Other value for this 
parameter will cause the command to terminate with a CHECK CONDITION status. The sense key is set to ILLEGAL 
REQUEST, and the additional sense code is set to INVALID FIELD IN CDB. 

The ALLOCATION LENGTH field indicates how much space has been reserved for the returned parameter data. If 
the length is not sufficient to contain all the parameter data, the first portion of the data is returned. This is not 
considered an error. The actual length of the parameter data is available in the IDENTIFIER LENGTH field in the 
parameter data. If the remainder of the parameter data is required, the application client should send a new REPORT 
DEVICE IDENTIFIER command with an ALLOCATION LENGTH field large enough to contain all the data. 

The REPORT DEVICE IDENTIFIER parameter list contains a 4-byte field that contains the length in bytes of the 
parameter list and the logical unit's identifier. 


Table 215 Report Device Identifier parameter list 


Byte 

Bit 

7 1 

6 

1 5 1 4 1 3 1 2 1 

1 0 

0-3 

(MSB) 


Identifier Length = n - 3 

(LSB) 

4-n 

Identifier 


The IDENTIFIER LENGTH field specifies the length in bytes of the IDENTIFIER field. If the ALLOCATION LENGTH 
field in the CDB is too small to transfer all of the identifier, the length is not adjusted to reflect the truncation. The 
identifier length initially equals zero and is changed only by a successful SET DEVICE IDENTIFIER command. 

The IDENTIFIER field contains a vendor specific value. The value reported is the last value written by a successful 
SET DEVICE IDENTIFIER command. The value of the identifier is changed only by a SET DEVICE IDENTIFIER 
command. The identifier value persist through resets, power cycles, media format operations. 

The Target return the same Identifier to all Initiators on all ports. 

The execution of a REPORT DEVICE IDENTIFIER requires the enabling of a nonvolatile memory within the logical 
unit. If the nonvolatile memory is not ready, the drive returns Check Condition status rather than wait for the device 
to become ready. The sense key is set to Not Ready and the additional sense data is set as described in the TEST 
UNIT READY command. This information should allow the application client to determine the action required to cause 
the drive to become ready. 
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8.34 REPORT LUNS (AO) 


Table 216 REPORT LUNS (AO) 


Byte 

Bit 

1 7 1 6 

1 5 1 4 1 3 1 2 

10 

0 

Command Code = AOh 

1-5 

Reserved 

6-9 

(MSB) 

Allocation Length 

(LSB) 

10 

Reserved 

11 

VU = 0 

Reserved = 0 

FLAG LINK 


The REPORT LUNS command requests that the Target return the known LUN to the Initiator. The REPORT LUNS 
command should always be available and is unaffected by any reservations. 

The Allocation Length must be at least 16 bytes. If the Allocation Length is less than 16 bytes, the Target will return 
a Check Condition status with sense key of Illegal Request and additional sense code of Invalid Field in CDB. If the 
Allocation Length is not sufficient to contain the LUN values for all configured logical units, the Target shall report as 
many LUN values as will fit in the specified Allocation Length. This is not considered an error. 

The REPORT LUNS command will send the LUN list in the subsequent Data Out Phase. The format of the LUN list 
is shown in the following table. 


Table 217 LUN Reporting parameter list format 


Byte 

Bit 

7 6 5 4 3 21 0 

0-3 

(MSB) 

LUN List Length = 8 

(LSB) 

4-7 

Reserved 

8-15 

(MSB) 

LUN = 0 

(LSB) 


The LUN list length shall contain the length in bytes of the LUN list that is available to be transferred. This product 
only supports one LUN. Therefore, the LUN list length must be set to 8. The only supported LUN is zero. 
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8.35 REPORT SUPPORTED OPERATION CODES (A3/0C) 


Table 218 REPORT SUPPORTED OPERATION CODES (A3/0C) 


Byte 

Bit 

7 6 5 4 3 21 0 

0 

Command Code = A3h 

1 

Reserved = 0 Service Action = OCh 

2 

RCTD Reserved = 0 Reporting Options 

3 

Requested Operation Code 

4-5 

Requested Service Action 

6-9 

Allocation Length 

10 

Reserved = 0 

11 

VU = 0 Reserved FLAG LINK 


The REPORT SUPPORTED OPERATION CODES command requests information on commands that the drive 
supports. The initiator may request a list of all operation codes and service actions supported, or the command 
support data for a specific command. 

RCTD: A return command timeouts descriptor (RCTD) bit set to one specifies that the command timeouts descriptor 
shall be included in each command descriptor (see section 8.35.1) that is returned or in the one_command parameter 
data (see section 8.35.2) that is returned. A RCTD bit set to zero specifies that the command timeouts descriptor 
shall not be included in any parameter data returned. 

Reporting Options specifies the information to be returned in the parameter data. 


Table 219 Reporting Options 


Reporting Options 

Description 

000b 

A list of all operation codes and service actions supported by the drive will be returned 
in the all_commands parameter data format. The Requested Operation Code field and 
Requested Service Action field will be ignored. 

001b 

The command support data for the operation code specified in the Requested 

Operation Code field will be returned in the one_command parameter data format. The 
Requested Service Action field will be ignored. If the Requested Operation Code field 
specifies an operation code that has service actions, Check Condition status will be 
reported with a sense key of Illegal Request and additional sense code of Invalid Field 
in CDB. 

010b 

The command support data for the operation code and service action specified in the 
Requested Operation Code field and Requested Service Action field will be returned in 
the one_command parameter data format. If the Requested Operation Code field 
specifies an operation code that does not have service actions, Check Condition status 
will be reported with a sense key of Illegal Request and additional sense code of Invalid 
Field in CDB. 

01 lb-111b 

Reserved 


Requested Operation Code specifies the operation code of the command to be returned in the one_command 
parameter data format. 

Requested Service Action specifies the service action of the command to be returned in the one_command 
parameter data format. 

Allocation Length specifies the number of bytes that have been allocated for the returned parameter data. If the 
length is not sufficient to contain all the parameter data, the first portion of the data shall be returned. The actual 
length of the parameter data may be determined from the Additional Length field in the parameter data. 
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8.35.1 All_commands parameter data format 

The Report Supported Operation Codes all_command parameter data format begins with a four-byte header that 
contains the length in bytes of the parameter data, followed by a list of supported commands. Each command 
descriptor contains information about a single supported command CDB (i.e. one operation code and service action 
combination, or one non-service action operation code). 


Table 220 All_command parameter data format 


Byte 

Bit 

7 1 6 | 5 | 4 | 3 | 2 | i | 0 

0-3 

Command Data Length (n-3) 

4 

Command Descriptor 0 

N 

Command Descriptor X 


Each Command Descriptor contains information about a single supported command CDB. 
Table 221 Command Descriptor format 


Byte 

Bit 

7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 

0-3 

Operation Code 

1 

Reserved = 0 

2-3 

Service Action 

4 

Reserved = 0 

5 

Reserved = 0 CTDP Servactv 

6-7 

CDB Length 

8-19 

Command Timeouts Descriptor, if any 
(see 8.35.3 "Command timeouts descriptor format") 


Operation Code contains the operation code of a supported command. 

Service Action contains a supported service action of the supported operation. If the operation code does not have 
a service action, the Service Action field will be set to zero. 

CTDP: A command timeouts descriptor present bit set to one indicates that the command timeouts descriptor (see 
8.35.3 Command timeouts descriptor format) is included in this command descriptor. A CTDP bit set to zero indicates 
that the command timeouts descriptor is not included in this command descriptor. 

Servactv set to zero indicates the operation code does not have service actions and the Service Action field should 
be ignored. SERVACTV set to one indicates the operation code field has service actions and the contents of the 
Service Action field are valid. 

CDB Length contains the length of the command CDB in bytes. 
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8.35.2 One_command parameter data format 

The Report Supported Operation Codes one_command parameter data format contains information about the CDB 
and a usage map for bits in the CDB for the command specified by the Reporting Options, Requested Operation 
Code, and Requested Service Action fields in the Reported Supported Operation Codes CDB. 


Table 222 One_command parameter data format 


Byte 

Bit 

7 1 6 | 5 | 4 | 3 | 2 | 1 | 0 

0 

Reserved = 0 

1 

CTDP Reserved = 0 Support 

2-3 

CDB Size (n-3) 

4-n 

CDB Usage Data 

n+1 - n+12 

Command Timeouts Descriptor, if any 
(see 8.35.3 "Command timeouts descriptor format") 


CTDP: A command timeouts descriptor present bit set to one indicates that the command timeouts descriptor is 
included in this command descriptor, (see section 8.35.3 "Command timeouts descriptor format") A CTDP bit set to 
zero indicates that the command timeouts descriptor is not included in this command descriptor. 

The Support field is defined in the table below. 


Table 223 One_command parameter support field 


Recording Option 

Description 

000b 

Data about the requested command is not currently available. All data after byte 1 is not 
valid. A subsequent request for command support data may be successful. 

001b 

The requested command is not supported. All data after byte 1 is not valid. 

010b 

Reserved. 

011b 

The requested command is supported in conformance with the standard. 

100b 

Reserved 

101b 

The requested command is supported in a vendor specific manner. 

110b-111b 

Reserved. 


CDB Size contains the size of the CDB Usage Data field in the parameter data, and the number of bytes in the CDB 
for the command requested. 

CDB Usage Data contains information about the CDB for the command requested. The first byte of the CDB Usage 
Data field contains the operation code for the command. If the command contains a service action, then that service 
action code is returned in the same location as the Service Action field of the command CDB. All other bytes of the 
CDB Usage Data field contain a usage map for bits in the CDB for the command requested. 

The bits in the usage map have a one-for-one correspondence to the CDB for the command requested. If the drive 
evaluates a bit in the CDB, the usage map will contain a one in the corresponding bit position. The usage map will 
contain a zero in the corresponding bit position for any field treated as ignored or reserved. 
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8.35.3 Command timeouts descriptor format 
8.35.3.1 Overview 

The command timeouts descriptor (see Table 224) returns time-out information for commands supported by the 
logical unit based on the time from the start of processing for the command to its reported completion. Values returned 
in the command timeouts descriptor do not include times that are outside the control of the drive (e.g., prior commands 
with the IMMED bit set to one in the CDB, concurrent commands from the same or different l_T nexuses, manual 
unloads, power-on self tests, prior aborted commands, commands that force cache synchronization, delays in the 
service delivery subsystem). 

For commands that cause a change in power condition (Idle/Standby Powersave Modes), values returned in the 
command timeouts descriptor do not include the power condition transition time (e.g., the time to spinup rotating 
media). 

Values returned in the command timeouts descriptor should not be used to compare products. 


Table 224 Command timeouts descriptor format 


Byte 

Bit 

7 He r~5 i 4 r~3 r~2 i i i 6 

0-1 

Descriptor Length (OAh) 

2 

Reserved = 0 

3 

Command Specific 

4-7 

Nominal Command Processing Time-out 

8-11 

Recommended Command Time-out 


The DESCRIPTOR LENGTH field indicates the number of bytes that follow in the command timeouts descriptor. 

The COMMAND SPECIFIC field contains time-out information (see Table 225) that is specific to one or more 
commands. 

If no command specific time-out information is defined by this or the applicable command standard, 
the COMMAND SPECIFIC field is reserved. 

Table 225 Command timeouts descriptor Command Specific Field usage 


Command 

Reference 

WRITE BUFFER 

See Section 8.35.3.2 "WRITE BUFFER: command timeouts descriptor COMMAND 
SPECIFIC field usage" 
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8.35.3.2 WRITE BUFFER: command timeouts descriptor COMMAND 
SPECIFIC field usage 

For the WRITE BUFFER command, the COMMAND SPECIFIC field usage is reserved for all modes except the 
following: 

• Download microcode mode (04h); 

• Download microcode and save mode (05h); 

• Download microcode with offsets mode (06h); 

• Download microcode with offsets and save mode (07h); 

• Download microcode with offsets and defer activation mode (OEh) only if the microcode is activated by an event 
other than an activate deferred microcode mode; and 

• Activate deferred microcode mode (OFh). 

If the command timeouts descriptor describes one of the WRITE BUFFER modes listed in this subclause, then the 

COMMAND SPECIFIC field indicates the maximum time, in one second increments, that access to the SCSI device 
is limited or not possible through any SCSI ports associated with a logical unit that processes a WRITE BUFFER 
command that specifies one of the named modes. A value of zero in the COMMAND SPECIFIC field indicates that 
the no maximum time is indicated. 
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8.36 REPORT SUPPORTED TASK MANAGEMENT FUNCTIONS 
(A3/0D) 


Table 226 Report Supported Task Management Functions (A3/0D) 


Byte 

Bit 

7 6 5 4 3 21 0 

0 

Command Code = A3h 

1 

Reserved = 0 Service Action = ODh 

2-5 

Reserved = 0 

6-9 

Allocation Length 

10 

Reserved = 0 

11 

VU = 0 Reserved = 0 Flag Link 


The REPORT SUPPORTED TASK MANAGEMENT FUNCTIONS command requests information on task 
management functions supported by the drive. 

Allocation Length specifies the number of bytes that have been allocated for the returned parameter data. The 
allocation length must be at least four. If the allocation length is less than four, Check Condition Status will be returned 
with sense key of Illegal Request and additional sense code of Invalid Field in CDB. 

The format of the returned parameter data is shown below. 


Table 227 Report Supported Task Management Functions - returned parameter data 


Byte 

Bit 

7 

6 

5 

4 

3 

2 

1 

0 

0 

ATS 

ATSS 

CACAS 

CTSS 

LURS 

QTS 

TRS 

WAKES 

1 

Reserved 

QUAS 

QTSS 

ITNRS 

2 

Reserved 

3 

Reserved 


ATS (Abort Task) bit set to one indicates that ABORT TASK is supported. An ATS bit of zero indicates that ABORT 
TASK is not supported. 

ATSS (Abort Task Set) bit set to one indicates that ABORT TASK SET is supported. An ATSS bit of zero indicates 
that ABORT TASK SET is not supported. 

CACAS (Clear ACA) bit set to one indicates that CLEAR ACA is supported. A CACAS bit of zero indicates that 
CLEAR ACA is not supported. 

CTSS (Clear Task Set) bit set to one indicates that CLEAR TASK SET is supported. A CTSS bit of zero indicates 
that CLEAR TASK SET is not supported. 

LURS (Logical Unit Reset) bit set to one indicates that LOGICAL UNIT RESET is supported. An LUR bit of zero 
indicates that LOGICAL UNIT RESET is not supported. 

QTS (Query Task) bit set to one indicates that QUERY TASK is supported. A QTS bit of zero indicates that QUERY 
TASK is not supported. 

TRS (Target Reset) bit set to one indicates that TARGET RESET is supported. A TRS bit of zero indicates that 
TARGET RESET is not supported. 

WAKES (Wakeup) bit set to one indicates that WAKEUP is supported. A WAKES bit of zero indicates that WAKEUP 
is not supported. 

A QUERY UNIT ATTENTION supported (QUAS) bit set to one indicates the QUERY UNIT ATTENTION task 
management function (see SAM-4) is supported by the logical unit. A QUAS bit set to zero indicates the QUERY 
UNIT ATTENTION task management function is not supported. 

A QUERY TASK SET supported (QTSS) bit set to one indicates the QUERY TASK SET task management function 
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(see SAM-4) is supported by the logical unit. A QTSS bit set to zero indicates the QUERY TASK SET task 
management function is not supported. 

An I T NEXUS RESET supported (ITNRS) bit set to one indicates the l_T NEXUS RESET task management function 
(see SAM-4) is supported by the logical unit. An ITNRS bit set to zero indicates the l_T NEXUS RESET task 
management function is not supported. 
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8.37 REQUEST SENSE (03) 


Table 228 REQUEST SENSE (03) 


Byte 

Bit 

7 6 

5 4 3 2 

1 

0 

0 

Command Code = 03h 

1 

Reserved = 0 

DESC 

2-3 

Reserved = 0 

4 

Allocation Length 

5 

VU = 0 

Reserved = 0 

FLAG 

LINK 


The REQUEST SENSE command requests the drive to transfer sense data. 

The Descriptor Format (DESC) bit specifies which sense data format the device shall return in the parameter data. 
The Allocation Length specifies the maximum number of bytes of sense data that the drive should return. Such 
relationship is shown in the table below. (See 15 SCSI Sense Data for more details). 

Table 229 Sense Data Format and Length 


DESC Bit 

Sense Data Format 

Length of Sense Data Returned 

Ob 

Fixed format 

The number of bytes in the Allocation Length or 32 bytes, whichever is less 

1b 

Descriptor format 

The number of bytes in the Allocation Length or a fixed "descriptor sense data 
size", whichever is less. The "descriptor sense data size" is either 40 or 60 
bytes, depending on the drive firmware build. 


If REQUEST SENSE command with an invalid LUN is received, the drive returns Good status and reports a sense 
key of Illegal Request and an additional sense code of Logical Unit Not Supported. 

If the drive has no sense data available to return, it will return a sense key of No Sense and an additional sense code 
of No Additional Sense Information. 

Separate sense data is maintained by the device for each Initiator. Therefore, there is no requirement for an Initiator 
to expeditiously clear a Check Condition as this will not affect other initiators in a multi-initiator system. 
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8.38 RESERVE (16) 


Table 230 RESERVE (16) 


Byte 

Bit 

7 6 

5 

4 

3 2 

1 

0 

0 

Command Code = 16h 

1 

Reserved = 0 

3rdPty=0 

3rd Party ID 

Ext=0 

2 

Reservation Identification 

3-4 

(MSB) 

Extent List Length = 0 

(LSB) 

5 

VU = 0 

Reserved = 0 

FLAG 

LINK 


The RESERVE command is used to reserve a LUN for an Initiator. This reservation can be either for the Initiator 
sending the command or for a third party as specified by the Initiator. 

Extents are not supported by the drive. The Ext bit must be zero. If Ext bit is set to one, Check Condition status is 
returned with a sense key of Illegal Request and additional sense code of Invalid Field in CDB. The Reservation 
Identification and Extent List Length fields are ignored. 

The Reserve command requests that the entire LUN be reserved for the Initiator until 

• the reservation is superseded by another valid Reserve command from the Initiator that made the reservation. 

• the reservation is released by a RELEASE command from the same Initiator. 

• a hard Reset condition occurs. 

• a Target Reset message is received from any Initiator. 

• a power off/on cycle occurs. 

3rdPty must be 0. Third Party reservations are not supported. If the 3rdPty bit is not zero, Check Condition status 
is returned with a sense key of Illegal Request and additional sense code of Invalid Field in CDB. 

3rd Party ID is ignored. 

Only the Initiator that issued the Reserve command for a LUN may release the LUN, regardless of the 3rdPty option. 
This Initiator may also release the LUN by issuing another RESERVE command. This superseding RESERVE 
command releases the previous reservation when the new reservation is granted. 

Reservation queuing is not supported by the drive. If a LUN is reserved and a RESERVE command is issued from a 
different Initiator, the Target responds with a RESERVATION CONFLICT. 
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8.39 RESERVE (56) 


Table 231 RESERVE (56) 


Byte 

Bit 

7 6 

5 

4 

3 2 

1 

0 

0 

Command Code = 56h 

1 

Reserved = 0 

3rdPty=0 

Reserved 

Ext=0 

2 

Reservation Identification 

3 

Third Pay Device ID 

4-6 

Reserved = 0 

7-8 

(MSB) 

Extent List Length = 0 
(LSB) 

9 

VU = 0 

Reserved = 0 

FLAG 

LINK 


The RESERVE command is used to reserve a LUN for an Initiator. This reservation can be either for the Initiator 
sending the command or for a third party as specified by the Initiator. 

Extents are not supported by the drive. The Ext bit must be zero. If Ext bit is set to one, Check Condition status is 
returned with a sense key of Illegal Request and additional sense code of Invalid Field in CDB. The Reservation 
Identification and Extent List Length fields are ignored. 

The Reserve command requests that the entire LUN be reserved for the Initiator until 

• the reservation is superseded by another valid Reserve command from the Initiator that made the reservation. 

• the reservation is released by a RELEASE command from the same Initiator. 

• a hard Reset condition occurs. 

• a Target Reset message is received from any Initiator. 

• a power off/on cycle occurs. 

3rdPty must be 0. Third Party reservations are not supported. If the 3rdPty bit is not zero, Check Condition status 
is returned with a sense key of Illegal Request and additional sense code of Invalid Field in CDB. 

3rd Party ID is ignored. 

Only the Initiator that issued the Reserve command for a LUN may release the LUN, regardless of the 3rdPty option. 
This Initiator may also release the LUN by issuing another RESERVE command. This superseding RESERVE 
command releases the previous reservation when the new reservation is granted. 

Reservation queuing is not supported by the drive. If a LUN is reserved and a RESERVE command is issued from a 
different Initiator, the Target responds with a RESERVATION CONFLICT. 
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8.40 REZERO UNIT (01) 


Table 232 REZERO UNIT (01) 


Byte 

Bit 

7 6 

5 

4 3 2 

1 

0 

0 

Command Code = 01 h 

1 

Reserved = 0 

Reserved = 0 

2-4 

Reserved = 0 

5 

VU = 0 

Reserved = 0 

FLAG 

LINK 


The REZERO UNIT command requests that the Target seek LBA 0. 
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8.41 SANITIZE (48) 


Table 233 SANITIZE (48) 


Byte 

Bit 

7 

6 

5 

4 3 2 

1 

0 

0 

Command Code = 48h 

1 

Immed 

RSVD 

AUSE 

Service Action 

2-6 

Reserved 

7-8 

Parameter List Length = 0 

9 

VU = 0 

Reserved 

FLAG 

LINK 


• Immed bit is to specify 
Table 234 Immed 


0 

status is to be returned at the end of the operation. 

~T~ 

Good status shall always be returned immediately after command has been received. The TEST UNIT READY 
command may be used to determine when the drive becomes ready. 


AUSE bit can be set to 1 to allow EXIT FAILURE MODE service action on a subsequent SANITIZE. If AUSE is 
set to 0, and the sanitize fails, a subsequent SANITIZE with EXIT FAILURE MODE will be rejected. 

Parameter List Length must be 0. If not, the drive returns a Check Condition status. The sense key is set to 
Illegal Request and the additional sense data is set to Invalid Field in CDB. 
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8.41.1 Sanitize (48) Service Action Codes 

The following service action codes are implemented. If a reserved service action code is specified, the drive returns 
a Check Condition status. The sense key is set to Illegal Request and the additional sense data is set to Invalid Field 
in CDB. 


Table 235 SANITIZE Service Action Codes 


Code 

Name 

Descriptions 

00-01 h 

Reserved 

Returns Check Condition 

01 h 

Overwrite 

Causes the drive to alter information by writing a data pattern to the medium 
one or more times 

02 h 

Reserved 

Retunes Check Condition 

03 h 

Cryptographic Erase 

Alters the drive internal encryption key to make user data/information 
unreadable 

04h-1 Eh 

Reserved 

Returns Check Condition 

1 Fh 

Exit Failure Mode 

If a prior Sanitize operation was issued with AUSE = 1 and it failed, this will 
take the drive out of degraded mode, Sanitize Failed state. 


Table 236 Parameter List Format for Overwrite Service Action 


Byte 

Bit 

7 

6 5 

4 | 3 | 2 | 1 | 0 

0 

Invert 

Test 

Overwrite Count 

1 

Reserved 

2 

(MSB) 

Initialization Pattern Length (n - 3) 

(LSB) 

3 

4 

Initialization Pattern 

... 

n 


• Invert bit set to zero indicates that the initialization pattern and protection information bytes, if any, are written 
as specified in the Initialization Pattern field on each overwrite pass. If the Invert bit is set to one, then the 
initialization pattern and protection information bytes, if any, shall be inverted (i.e., each bit XORed with one) 
between consecutive overwrite passes. 

• Overwrite Count field specifies the number of overwrite passes to be performed. The value of OOh is reserved. 

• Initialization Pattern Length field specifies the length in bytes of the Initialization Pattern field. The Initialization 
Pattern Length field shall be greater than zero and shall not exceed the logical block length. If the Initialization 
Pattern Length field is set to zero or a value greater than the logical block length, then the drive shall terminate 
the command with Check Condition status with the sense key set to Illegal Request and the additional sense 
code set to Invalid Field in Parameter List. 

Initialization Pattern field specifies the data pattern to be used to write the user data. This data pattern is repeated as 
necessary to fill each logical block. For each logical block, the first byte of the user data shall begin with the first byte 
of the initialization pattern. The protection information, if any, shall be set to FFFF_FFFF_FFFF_FFFFh 
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8.42 SEND DIAGNOSTIC (ID) 


Table 237 SEND DIAGNOSTIC (ID) 


Byte 

Bit 

765 

4 3 1 

2 


0 

0 

Command Code = 1 Dh 

1 

Function Code 

PF RSVD =0 

SlfTst 

DevOfl 

UntOfl 

2 

Reserved = 0 

3-4 

(MSB) 

Parameter List Length 



(LSB) 

5 

VU = 0 

Reserved = 0 


FLAG 

LINK 


The SEND DIAGNOSTIC command requests the drive to perform its self-diagnostic test or to perform a function 
based on a page of information sent in a Data Out phase during the command. 

• PF (Page Format) bit set to one indicates the data sent by the Initiator conform to the page structure as specified 
in SCSI standard. This bit is ignored by the Target if the SlfTst bit is set. 

• SlfTst set to one indicates that the device performs its default self-test. If SlfTst is one, the Function code field 
is ignored. If SlfTst is set to zero, the action to perform is specified in Function code field. 


Table 238 SEND DIAGNOSTIC Function Code (ID) 


Value 

Function name 

Description 

000b 

NA 

Value to be used when the SlfTst bit is set to one or if the SEND 
DIAGNOSTIC command is not invoking one of the other self-test 
function codes. 

001b 

Background Short self-test 

The drive starts its short self-test routine in background mode. 

010b 

Background extended self-test 

The drive starts its extended self-test routine in background mode. 

011b 

NA 

Reserved. 

100b 

Abort background self-test 

Abort the current self-test in the background mode. This value is only 
valid if a previous SEND DIAGNOSTIC command specified a 
background self-test function and that function has not been 
completed. 

101b 

Foreground short self-test 

The drive starts its short self-test routine in the foreground mode. This 
self-test will complete in two minutes or less. 

110b 

Foreground extended self-test 

The drive starts its extended self-test routine in the foreground 
mode .The completion time for this test is reported in Mode Page OAh 
(refer to section 8.11.9 "Mode Page 0A (Control Mode Page 
Parameters)”). 

111b 

Reserved. 


• DevOfl is ignored by the Target for compatibility. 

• UntOfl is ignored by the Target for compatibility. 

• Parameter List Length must be 0 when the SlfTst bit is one. Otherwise, Check Condition status will be 
generated with a sense key of Illegal Request and additional sense of Invalid Field in CDB. If the SlfTst bit is 
zero, it should be set to the length of the page to be transferred in the DATA OUT phase of the command. If it 
does not match the expected length of the page a Check Condition status will be also generated with a sense 
key of Illegal Request and additional sense of Invalid Field in CDB. 

If the motor is not running at the correct speed when the command is received, it is rejected by a Check Condition 
status with a Not Ready sense key. 


HGST Hard Disk Drive OEM Specification 
215 




If a fault is detected during the default or foreground self-test, a Check Condition is reported as an end status. If a 
fault is detected during the background self-test, it is logged in the log page for later retrieval by a LOG SENSE 
command. 

See Section 10.12 Diagnostics for a detailed listing of operations carried out by the SEND DIAGNOSTIC command 
and Power on Diagnostics. 


8.42.1 Send Diagnostic Page 0 

This page requests that the drive return a list of supported pages on the next RECEIVE DIAGNOSTICS command. 
Table 239 Diagnostic page 0 


Byte 

Bit 

7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 

0 

Page Code = 0 

1 

Reserved = 0 

2-3 

Page Length = 0 


8.42.2 Send Diagnostic Page 3F 

Table 240 Diagnostic page 3F 


Byte 

Bit 

7 

1 6 

5 4 

3 | 2 | 1 | 0 | 

0 

Page Code = 3F 

1 


Reserved = 

= 0 

Protocol Identifier = 6 

2-3 

Page Length = ICh 

4 

Phy Identifier 

5 

Phy Test Function 

6 

Phy Test Pattern 

7 

Rsvd=0 

Phy Test 
Pattern 
SATA = 0 

Phy Test 
Pattern 
SSC 

Phy Test Pattern Physical Link Rate 

8-10 

Reserved = 0 

11 

Phy Test Pattern Dwords Control 

12-19 

Phy Test Pattern Dwords 

20-31 

Reserved = 0 


Phy Identifier specifies the selected phy that is to perform or to stop performing a phy test function. If the phy 
does not exist, Check Condition status will be returned with a sense key of Illegal Request and additional sense 
of Invalid Field in Parameter List. 

Phy Test Function specifies the phy test function to be performed. If an unsupported function is requested, Check 
Condition status will be returned with a sense key of Illegal Request and additional sense of Invalid Field in 
Parameter List. 
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Table 241 Phy Test Function 


Phy Test 
Function 

Description 

OOh 

If the selected phy is performing a phy-test function, then the selected phy stop performing the phy 
test function and originate a link reset sequence. If the selected phy is not performing a phy test 
function, then this function as no effect on the selected phy. 

01 h 

If the selected phy is not performing a phy test function, the selected phy will be set to transmit the 
phy test pattern specified by the Phy Test Pattern field at the physical link rate specified by the Phy 
Test Pattern Physical 

02h-FDh 

Unsupported 

FEh 

Analog Loopback - If the selected phy is not performing a phy test function, the selected phy will be 
set to retransmit the data pattern received by the phy receiver without retime 

FFh 

Retime Loopback- If the selected phy is not performing a phy test function, the selected phy will be 
set to retransmit the retimed data pattern received by the phy receiver 


Phy Test Pattern specifies the phy test pattern to be transmitted when the Phy Test Function is set to 01 h. If an 
unsupported value is specified, Check Condition status will be returned with a sense key of Illegal Request and 
additional sense of Invalid Field in Parameter List. 


Table 242 Phy Test Pattern 


Phy Test Pattern 

Description 

OOh 

Reserved 

01 h 

JTPAT 

02 h 

CJTPAT 

03h-0Fh 

Reserved 

lOh 

TRAIN 

11 h 

TRAINDONE 

13h 

SCRAMBLER 

12h 

IDLE 

14h - 3Fh 

Reserved 

40 h 

TWO_DWORDS 

41 h - Efh 

Reserved 

FOh 

PRBS7 (DC un-balanced version) 

Flh-FFh 

Reserved 


Phy Test Pattern Physical Link Rate specifies the physical link rate at which the phy test pattern shall be 
transmitted. Supported values are 8h for 1.5 Gbps, 9h for 3.0 Gbps, and Ah for 6.0 Gbps. If an unsupported 
value is specified, Check Condition status will be returned with a sense key of Illegal Request and additional 
sense of Invalid Field in Parameter List. 

Phy Test Pattern SATA bit set to 0 indicates that the phy transmits the phy test pattern as a SAS phy. If this bit 
is set to 1, Check Condition status will be returned with a sense key of Illegal Request and additional sense of 
Invalid Field in Parameter List 

Phy Test Pattern SSC field specifies the SSC modulation type which the phy test pattern will be transmitted. If 
an unsupported SSC modulation type is specified, Check Condition status will be returned with a sense key of 
Illegal Request and additional sense of Invalid Field in Parameter List. 
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Table 243 Phy Test Pattern SSC Code 


Phy Test Pattern 
SSC Code 

Description 

OOh 

No SSC 

01 h 

Center-spreading SSC (Not supported) 

lOh 

Down-spreading SSC 

11 h 

Reserved 


• Phy Test Pattern Dwords Control controls whether the bytes in the Phy Test Pattern Dwords field are sent as 
control characters or data characters. 

Table 244 Phy Test Pattern Dwords Control 


Phy Test Pattern 
Dwords Control 

Description 

OOh 

Each byte in the Phy Test Pattern Dwords field shall be sent as a data character (i.e., Dxx.y) 
without scrambling. 

08 h 

The fifth byte in the Phy Test Pattern Dwords field shall be sent as a control character (i.e., 
Kxx.y). Each other byte shall be sent as a data character without scrambling. 

80h 

The first byte in the Phy Test Pattern Dwords field shall be sent as a control character. Each 
other byte shall be sent as a data character without scrambling. 

88 h 

The first and fifth bytes in the Phy Test Pattern Dwords field shall be sent as a control 
character. Each other byte shall be sent as a data character without scrambling. 

All others 

Reserved 


• Phy Test Pattern Dwords contains the two Dwords that are sent during a TWO_DWORDS test pattern. 
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8.42.3 Send Diagnostic Page 40 

This allows the Initiator to translate a LBA or physical sector address to the other format. The address to be translated 
is passed to the Target with the SEND DIAGNOSTIC command and the results are returned to the Initiator by the 
RECEIVE DIAGNOSTICS command. The Target will read the parameter list from the Initiator, and, if no errors are 
detected in the parameter list, Good status will be returned. The data translation will be performed upon receipt of 
the RECEIVE DIAGNOSTICS command. 


Table 245 Diagnostic Page 40 


Byte 

Bit 

7 1 6 | 5 | 4 | 3 | 2 | 1 | 0 

0 

Page Code = 0 

1 

Reserved = 0 

2-3 

Page Length = 0 

4 

Reserved = 0 

Supplied Format 

5 

Reserved = 0 

Translate Format 

6-13 

Address to Translate 


Supplied Format may take one of the following three values: 

Table 246 Supplied Format 

000 b 

Short Block format 


011 b 

Long Block format 

100 b 

Bytes From Index format 

101 b 

Physical Sector format 


It specifies the format in which the address has been supplied. 

• Translate Format specifies the format that the address should be translated into. If the Supplied Format is the 
Short Block format or Long Block format, the Translate format must be either Bytes From Index or Physical 
Sector format. If the Supplied Format is the Bytes From Index or Physical Sector format, the Translate Format 
must be Long Block format. If either of the format fields is invalid or they specify the same format, the command 
will terminate with Check Condition status with a sense code of Illegal Request and Illegal Field in Parameter 
List. 

• Address to Translate contains the address to translate. If the Short Block format is specified, the first four bytes 
of the field (bytes 6 to 9) contain the LBA and the remainder must be zero. If the Long Block format is specified, 
byte 6 to 13 contain the 64-bit LBA. For the physical format the address must be specified as follows. 


Table 247 Address to translate 


Byte 

Bit 

7 6 5 4 3 21 0 

6-8 

Cylinder Number 

9 

Head Number 

10-13 

Sector Number or Bytes from Index 
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8.43 SET DEVICE IDENTIFIER (A4/06) 


Table 248 SET DEVICE IDENTIFIER (A4/06) 


Byte 

Bit 

7 6 5 4 3 21 0 

0 

Command Code = A4h 

1 

Reserved = 0 Service Action = 06h 

2 

Reserved = 0 

3 

Reserved = 0 

4-5 

Restricted = 0 

6-9 

(MSB) 

Parameter List Length 

(LSB) 

10 

Reserved = 0 

11 

VU = 0 Reserved = 0 FLAG LINK 


The SET DEVICE IDENTIFIER command requests that the device identifier information be set to the value received 
in the SET DEVICE IDENTIFIER parameter list. 

On successful completion of a SET DEVICE IDENTIFIER command a unit attention is generated for all Initiators 
except the one that issued the service action. When reporting the unit attention condition the additional sense code 
is set to Device Identifier Changed. 

• Parameter List Length field specifies the length in bytes of the Identifier that is transferred from the host system 
to the Target. The maximum value for this field is 512 bytes. A parameter list length of zero indicates that no 
data is transferred, and that subsequent REPORT DEVICE IDENTIFIER commands return an Identifier length 
of zero. 


The SET DEVICE IDENTIFIER parameter list contains the identifier to be set by the addressed logical unit. 


Table 249 SET DEVICE IDENTIFIER, Parameter List 


Byte 


0-n 


Bit 

4 | 3 | 2 | 1 | ~0~ 

Identifier 


The IDENTIFIER field is a vendor specific value, to be returned in subsequent REPORT DEVICE IDENTIFIER 
commands. 
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8.44 STAET STOP UNIT (IB) 


Table 250 START STOP UNIT (IB) 


Byte 

Bit 

7 6 5 4 3 2 1 0 

0 

Command Code = IBh 

1 

Reserved = 0 Immed 

2 

Reserved = 0 

3 

Reserved = 0 

Power Condition Modifier 

4 

Power Condition 

Reserved=0 

LoEj= 0 

Start 

5 

VU = 0 Reserved = 0 

FLAG 

LINK 


The START STOP UNIT command is used to spin up or stop the spindle motor. 

• Immed bit is to specify 
Table 251 Immed 


0 

status is to be returned at the end of the operation. 

1 

Good status shall always be returned immediately after command has been received. The TEST UNIT 
READY command may be used to determine when the drive becomes ready after a spin-up. 


Power Conditions and Power Condition Modifier fields are used to specify that the logical unit be placed into 
a power condition or to adjust a timer as defined in Table 252, if this field is set to a value other than Oh, then the 
START bit shall be ignored. 


Table 252 Power Conditions 


Power 

Condition 

Code 

Name 

Power 

Condition 

Modifier 

Description 

Oh 

STARTVALID 

Oh 

Process the START bit 

1h 

ACTIVE 

Oh 

Place the device into the active power condition 

2h 

IDLEA 

Oh 

Place the device into the idle-a power condition 

2h 

IDLEB 

1h 

Place the device into the idle-b power condition 

2h 

IDLE_C 

2h 

Place the device into the idle-c power condition 

3h 

STANDBYZ 

Oh 

Place the device into the standby_Z power condition 

3h 

STANDBYY 

1h 

Place the device into the standby_Y power condition 

4h 

Reserved 

Oh 

Reserved 

5h 

Obsolete 

Oh-Fh 

Obsolete 

6h 

Reserved 

Oh 

Reserved 

7h 

LU_CONTROL 

Oh 

Transfer control of power conditions to the logical unit 

8h - 9h 

Reserved 

Oh 

Reserved 

Ah 

FORCE! DLEA 

Oh 

Force the idle_a condition timer to zero. 

Ah 

FORCE! DLEB 

1h 

Force the idle_b condition timer to zero. 

Ah 

FORCE! DLEC 

2h 

Force the idle_c condition timer to zero. 

Bh 

FORCESTANDBYZ 

Oh 

Force the standby_z condition timer to zero. 

Bh 

FORCESTANDBYY 

1h 

Force the standby_y condition timer to zero. 

all Others 

Reserved 

Oh 

Reserved 
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If the START STOP UNIT command is processed with the POWER CONDITION field set to ACTIVE, IDLE, or 
STANDBY, then: 

a) the logical unit shall transition to the specified power condition; and 

b) the drive shall disable the idle condition timer if it is active and disable the standby condition timer if it is active 
until another START STOP UNIT command is processed that returns control of the power condition to the logical 
unit, or a logical unit reset occurs. 

c) if under initiator control, the two minute floor and 60 head unloads per 24 hour period limits do not apply as they 
do when under logical unit/timer control 

If the START STOP UNIT command is processed with the POWER CONDITION field set to LU_CONTROL, then the 
drive shall initialize and start all of the idle condition timers and standby condition timers that are supported and 
enabled. 

If the START STOP UNIT command is processed with the POWER CONDITION field set to LU_CONTROL, then the 
drive shall enable the idle condition timer if it is active and disable the standby condition timer if it is active. 

If the START STOP UNIT command is processed with the POWER CONDITION field set to FORCE_IDLE_0 or 
FORCE STANDBY O, then the drive shall: 

a) force the specified timer to zero, cause the logical unit to transition to the specified power condition, and return 
control of the power condition to the drive; or 

b) terminate a START STOP UNIT command that selects a timer that is not supported by the drive or a timer that 
is not active. The drive shall terminate the command with CFIECK CONDITION status with the sense key set to 
ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN CDB. 

It is notan error to specify that the logical unit transition to its current power condition. See 8.11.13 “Mode Page 1A 
(Power Control)" for more information on idle and standby power conditions. 

• LoEj is not supported by the drive and must be set to 0. 

• Start bit is to specify: 


Table 253 Start bit 


0 

Stop the spindle 

1 

Stop the spindle 


Note: Once the drive has become ready (after a power on), the START STOP UNIT command can be used without 
any errors regardless of the state of the motor: stopped or spinning. 
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8.45 SYNCHRONIZE CACHE (10) - (35) 


Table 254 SYNCHRONIZE CACHE (10) - (35) 


Byte 

Bit 

7 6 

5 

4 3 2 

1 

0 

0 

Command Code = 35h 

1 

Reserved = 0 

Reserved = 0 

Immed = 0 

Obsolete 

2-5 

(MSB) 

Logical Block Address 

(LSB) 

6 

Reserved = 0 

7-8 

(MSB) 

Number of Blocks 

(LSB) 

9 

VU = 0 

Reserved = 0 

FLAG 

LINK 


The SYNCHRONIZE CACHE command ensures that logical blocks in the cache have their most recent data value 
recorded on the media. 

• Logical Block Address is to specify where the operation is to begin. 

• Immed (immediate) must be zero. An immediate bit of zero indicates that the status shall not be returned until 
the operation has completed. If the Immed bit is set to one, the drive returns a Check Condition status. The 
sense key shall be set to Illegal Request and the additional sense code shall be set to Invalid Field in CDB. 

• Number of Blocks specifies the total number of contiguous logical blocks within the range. Number of Blocks 
of zero indicates that all remaining logical blocks on the logical unit shall be within the range. 
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8.46 SYNCHRONIZE CACHE (16) - (91) 


Table 255 Synchronize Cache (16) - (91) 


Byte 

Bit 

7 6 

5 4 3 2 

1 

0 

0 

Command Code = 91 h 

1 

Reserved = 0 

Immed = 0 

Rsvd=0 

2-9 

Logical Block Address 

10-13 

Number of Blocks 

14 

Reserved = 0 

15 

VU = 0 

Reserved = 0 

FLAG 

LINK 


The SYNCHRONIZE CACHE command ensures that logical blocks in the cache have their most recent data value 
recorded on the media. See the SYNCHRONIZE CACHE (10) description for definitions of the fields in this 
command. 
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8.47 TEST UNIT READY (00) 


Table 256 TEST UNIT READY (00) 


Byte 

Bit 

7 6 

5 

4 3 2 

1 

0 

0 

Command Code = OOh 

1 

Reserved = 0 

Reserved = 0 

2-4 

Reserved = 0 

5 

vu = o 

Reserved = 0 

FLAG 

LINK 


The TEST UNIT READY command allows the Initiator to check if the drive is READY. The SCSI specification defines 
READY as the condition where the device will accept a media-access command without returning Check Condition 
status. 

The drive will first verify that the motor is spinning at the correct speed. If the spindle motor is not spinning at the 
correct speed, Check Condition status is returned with sense key of Not Ready. If the motor is spinning at the correct 
speed, the drive accepts normal media access commands. 

The TEST UNIT READY command is not intended as a diagnostic. No self diagnostic is performed by the device as 
a result of this command. 

The TEST UNIT READY command has special significance for power sequencing using the UNIT START command 
with an immediate bit of one. In this mode the UNIT START command returns Task Complete status before the 
completion of motor spin-up and expects the initiator to issue TEST UNIT READY commands to determine when the 
motor has reached the proper speed. 

Note: The spindle automatically starts in automatic spin-up mode. The drive does not execute any commands 

other than TEST UNIT READY, INQUIRY, or REQUEST SENSE command until the Power On sequence is complete. 
The drive will return Check Condition status with Not Ready sense key and In Process of Becoming Ready sense 
code for all other commands during the Power On period. 
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8.48 VERIFY (10) - (2F) 


Table 257 VERIFY (10)- (2F) 


Byte 

Bit 

7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 

0 

Command Code = 2Fh 

1 

VRPROTECT DPO Reserved = 0 ByteChk RSVD = 0 

2-5 

(MSB) 

Logical Block Address 

(LSB) 

6 

Reserved = 0 

7-8 

(MSB) 

Verification Length 

(LSB) 

9 

VU = 0 Reserved = 0 FLAG LINK 


The VERIFY command requests that the drive verify the data written on the media. A verification length of zero 
indicates that no data will be transferred. This condition is not considered an error. 

• ByteChk bit set to zero indicates that the data is read from the disk and verified using LDPC. If an LDPC error 
is detected in the verify process, Check Condition status is returned with sense key set to Medium Error. 
ByteChk bit set to one indicates that byte-by-byte comparison is performed between the data on the disk and 
data transferred from the initiator during the data-out phase. 

If the comparison is unsuccessful, the command is terminated with Check Condition status and the sense key is 
set to Miscompare. 

• DPO (Disable Page Out) bit of one indicates that the data accessed by this command is to be assigned the 
lowest priority for being written into or retained by the cache. A DPO bit of one overrides any retention priority 
specified in the Mode Select Page 8 Caching Parameters. A DPO bit of zero indicates the priority is determined 
by the retention priority. The Initiator should set the DPO bit when the blocks read by this command are not likely 
to be read again in the near future. 

If caching is enabled, the command performs an implied FUA and an implied Synchronize Cache before starting the 
VERIFY. This ensures that the medium, not the cache, is being verified. 

The command stops on Check Condition and reports the LBA in error. The command must be reissued, starting with 
the next LBA, to verify the remainder of the Drive. 

The Verification Length is the number of blocks to check. 

The data (if any) from the data-out phase and the data from the media are not retained in the cache. Therefore, the 
DPO bit has no effect on this command and is ignored. 

VRPROTECT defines the manner in which protection information read from disk shall be checked during processing 
of the command. Protection information is stored on disk, and may be validated using the drive's internal checking 
algorithms, and also byte-by-byte compared using data from the initiator when ByteChk=1. 

If the drive is not formatted with protection information, VRPROTECT must be set to 000b, else Check Condition 
status will be returned with sense key of Illegal Request and additional sense code of Invalid Field in CDB. 
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VRPROTECT=000b 

If the drive is not formatted with protection information, only user data is verified. 

If the drive is formatted with protection information: 

- Logical Block Guard is checked 

- Logical Block Application Tag is checked (applies to VERIFY(32) command only) 

- Logical Block Reference Tag is checked 
VRPROTECT=001 b 

- Logical Block Guard is checked 

- Logical Block Application Tag is checked (applies to VERIFY(32) command only) 

- Logical Block Reference Tag is checked 
VRPROTECT=01 Ob 

- Logical Block Guard is not checked 

- Logical Block Application Tag is checked (applies to VERIFY(32) command only) 

- Logical Block Reference Tag is checked 
VRPROTECT=011 b 

- Logical Block Guard is not checked 

- Logical Block Application Tag is not checked 

- Logical Block Reference Tag is not checked 
VRPROTECT=100b 

- Logical Block Guard is checked 

- Logical Block Application Tag is not checked 

- Logical Block Reference Tag is not checked 
VRPROTECT=101b, 110b, 111b 

These values are reserved. Check Condition status will be returned with sense key of Illegal Request and additional 
sense code of Invalid Field in CDB. 

If a check of the protection information fails, Check Condition status will be returned with sense key of Aborted 
Command and additional sense code indicating which protection field check failed. 

If ByteChk=1, the drive's internal checking of protection information is done only when VRPROTECT=000b and the 
drive is formatted with protection information 

If ByteChk=1, and VRPROTECT is not set to 000b, checking of protection information is performed on the fields 
described above as a byte-by-byte comparison against the data transferred to the drive by the initiator during the 
Data Out phase. 

Refer to the ANSI T10 standards for additional details of protection information. 
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8.49 VERIFY (12) - (AF) 


Table 258 VERIFY (12) - (AF) 


Byte 

Bit 

7 6 

5 

4 

3 

2 

1 

0 

0 

Command Code = AFh 

1 

VRPROTECT 

DPO 

FUA 

Reserved=0 

ByteChk 

Reserved = 0 

2-5 

(MSB) 

Logical Block Address 

(LSB) 

6-9 

(MSB) 

Verification Length 

(LSB) 

10 

Reserved = 0 

11 

vu = o 

Reserved = 0 

FLAG 

LINK 


The VERIFY (12) command causes the drive to verify data written on the media. See the VERIFY (10) description 
for the definitions of the fields in this command. 


HGST Hard Disk Drive OEM Specification 
228 




8.50 VERIFY (16) - (8F) 


Table 259 VERIFY (16)- (8F) 


Byte 

Bit 

7 6 

5 

4 

3 2 

1 

0 

0 

Command Code = 08Fh 

1 

VRPROTECT 

DPO 

Reserved = 0 

ByteChk 

Rsvd = 0 

2-9 

(MSB) 

Logical Block Address 
(LSB) 

10-13 

(MSB) 

Verification Length 
(LSB) 

14 

Reserved = 0 

15 

vu = o 

Reserved = 0 

FLAG 

LINK 


The VERIFY command requests that the drive verify the data written on the media. See the VERIFY (10) description 
for the definitions of the fields in this command. 
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8.51 

VERIFY (32) 

- (7F/0A) 


Table 260 

VERIFY (32) - 7F/0A) 



Byte 

Bit 

1 7 1 6 1 

5 4 3 2 1 

o ! 

0 

Command Code = 07Fh 

1 

| VU = 0 

Reserved = 0 FLAG 

LINK 

2-5 

Reserved = 0 

6 

Reserved = 0 

Group Number = 0 


7 

Additional CDB Length = 18h 

8-9 

Service Action = OOOAh 

10 

RDPROTECT 

DPO Reserved = 0 ByteChk 

Reserved=0 

11 

Reserved = 0 

12-19 

(MSB) 

Logical Block Address 

(LSB) 

20-23 

(MSB) 

Expected Initial Logical Block Reference Tag 

(LSB) 

24-25 

(MSB) 

Expected Logical Block Application Tag 

(LSB) 

26-27 

(MSB) 

Logical Block Application Tag Mask 

(LSB) 

28-31 

(MSB) 

Verification Length 

(LSB) 


The VERIFY command requests that the verify the data written on the media. Each logical block includes user data 
and may include protection information, based on the VPROTECT field and the drive format. 

If the drive is formatted with type 2 protection (PROT_EN=1 and P_TYPE=001b in the READ CAPACITY (16) 
parameter data), then this command will be processed normally. Any other protection types will result in Check 
Condition status to be returned with sense key of Illegal Request and additional sense code of Invalid Command 
Operation Code 

The Expected Initial Logical Block Reference Tag field contains the value of the Logical Block Reference Tag field 
expected in the protection information of the first logical block accessed by the command. 

If the ATO bit is set to one in Mode Page OAh, the Logical Block Application Tag Mask field contains a value that is a 
bit mask for enabling the checking of the Logical Block Application Tag field in the protection information for each 
logical block accessed by the command. A Logical Block Application Tag Mask bit set to one enables the checking 
of the corresponding bit of the Expected Logical Block Application Tag field with the corresponding bit of the Logical 
Block Application Tag field in the protection information. 

If the ATO bit is set to zero, the Logical Block Application Tag Mask field and the Expected Logical Block Application 
Tag field are ignored. 
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8.52 WRITE (6) - (OA) 


Table 261 WRITE (6) • (OA) 


Byte 

Bit 

7 6 5 4 3 21 0 

0 

Command Code = OAh 

1 

Reserved = 0 (MSB) LBA 

2-3 

Logical Block Address 

(LSB) 

4 

Transfer Length 

5 

VU = 0 Reserved = 0 FLAG LINK 
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8.53 WRITE (10) - (2A) 


Table 262 WRITE (10) - (2A) 


Byte 

Bit 

765 

1 4 1 3 1 2 

1 

o ! 

0 

Command Code = 2Ah 

1 

WRPROTECT 

DPO FUA Rsvd=0 

FUANV 

Obsolete 

2-5 

(MSB) 

Logical Block Address 


(LSB) 

6 

Reserved = 0 

9 

VU = 0 

Reserved = 0 

FLAG 

LINK 


The WRITE (10) command requests that the drive write the data transferred from the Initiator. This command is 
processed like the standard WRITE (6) - (0A) command except for the longer transfer length. 

• Transfer Length is the number of contiguous blocks to be transferred. If the transfer length is zero, the seek 
occurs, but no data is transferred. This condition is not considered an error. 

• DPO (Disable Page Out) bit of one indicates that the data accessed by this command is to be assigned the 
lowest priority for being written into or retained by the cache. A DPO bit of one overrides any retention priority 
specified in the Mode Select Page 8 Caching Parameters. A DPO bit of zero indicates that the priority is 
determined by the retention priority. The Initiator should set the DPO bit when the blocks written by this command 
are not likely to be read in the near future. 

• FUA (Force Unit Access) bit of one indicates that the Target must write the data to the media before returning 
Good status. A FUA bit of zero indicates that the Target may return Good status prior to writing the data to the 
media. 

• FUA_NV (Force Unit Access Non-Volatile Cache) may be set to 0 or 1, but is ignored since NV_SUP=0 in Inquiry 
Page 86h. 

If a WRITE (6) command is received after protection information is enabled, the drive will set the protection information 
as follows as it writes each block to disk: 

• the Logical Block Guard field is set to a properly generated CRC 

• the Logical Block Reference Tag field is set to: 

- the least significant four bytes of the LBA, if the drive is formatted with type 1 protection (PROT_EN=1 and 
P_TYPE=000b in the READ CAPACITY (16) parameter data); or 

- FFFFFFFFh, if the drive is formatted with type 2 protection (PROTJEN=1 and P_TYPE=001b in the READ 
CAPACITY (16) parameter data) 

• the Logical Block Application Tag field is set to 

- FFFFh, if the ATO bit is set to one in Mode Page OAh; or 

- Any value, if the ATO bit is set to zero 

WRPROTECT defines the manner in which protection information written to disk shall be checked during processing 
of the command. Protection information may be transmitted to the drive with the user data, based on the 
WRPROTECT bit and the drive format. 

If the drive is not formatted with protection information, WRPROTECT must be set to 000b, else Check Condition 
status will be returned with sense key of Illegal Request and additional sense code of Invalid Field in CDB. 

WRPROTECT=000b 

Protection information is not transmitted to the drive. 

If the drive is formatted with protection information, the drive will write protection information to disk based on its 
internal algorithms. 

WRPROTECT=001 b 

- Protection information is transmitted to the drive with the user data 
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- Logical Block Guard is checked 

- Logical Block Application Tag is checked (applies to WRITE (32) command only) 

- Logical Block Reference Tag is checked 

WRPROTECT=01 Ob 

- Protection information is transmitted to the drive with the user data 

- Logical Block Guard is not checked 

- Logical Block Application Tag is checked (applies to WRITE(32) command only) 

- Logical Block Reference Tag is checked 

WRPROTECT=011 b 

- Protection information is transmitted to the drive with the user data 

- Logical Block Guard is not checked 

- Logical Block Application Tag is not checked 

- Logical Block Reference Tag is not checked 

WRPROTECT=100b 

- Protection information is transmitted to the drive with the user data 

- Logical Block Guard is checked 

- Logical Block Application Tag is not checked 

- Logical Block Reference Tag is not checked 

WRPROTECT=101b, 110b, 111b 

These values are reserved. Check Condition status will be returned with sense key of Illegal Request and additional 
sense code of Invalid Field in CDB. 

If a check of the protection information fails, Check Condition status will be returned with sense key of Aborted 
Command and additional sense code indicating which protection field check failed. 

Refer to the ANSI T10 standards for additional details of protection information. 
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8.54 WRITE (12) - (AA) 


Table 263 WRITE (12) - (AA) 


Byte 

Bit 

765 

1 4 1 3 1 2 

1 

o ! 

0 

Command Code = AAh 

1 

WRPROTECT 

DPO FUA Rsvd=0 

FUANV 

Rsvd=0 

2-5 

(MSB) 

Logical Block Address 


(LSB) 

6-9 

(MSB) 

Transfer Length 


(LSB) 

10 

Reserved=0 

11 

VU = 0 

Reserved = 0 

FLAG 

LINK 


The WRITE (12) command causes the drive to write data from the initiator to the media. See the WRITE (10) 
description for the definitions of the fields in this command. 
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8.55 WRITE (16) - (8A) 


Table 264 WRITE (16) - (8A) 


Byte 

Bit 

765 

1 4 1 3 1 2 

1 

o ! 

0 

Command Code = 8Ah 

1 

WRPROTECT 

DPO FUA Rsvd=0 

FUANV 

Rsvd=0 

2-5 

(MSB) 

Logical Block Address 


(LSB) 

6-9 

(MSB) 

Transfer Length 


(LSB) 

10 

Reserved=0 

11 

VU = 0 

Reserved = 0 

FLAG 

LINK 


The WRITE (16) command causes the drive to write data from the initiator to the media. See the WRITE (10) 
description for the definitions of the fields in this command. 
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8.56 WRITE (32) - (7F/0B) 


Table 265 WRITE (32) - (7F/0B) 


Byte 

Bit 

7 6 5 4 3 2 1 0 

0 

Command Code = 7Fh 

1 

VU = 0 Reserved = 0 FLAG LINK 

2-5 

Reserved = 0 

6 

Reserved = 0 Group Number = 0 

7 

Additional CDB Length = 18h 

8-9 

Service Action = OOOBh 

10 

WRPROTECT DPO FUA Rsvd=0 FUA_NV Rsvd=0 

11 

Reserved = 0 

12-19 

(MSB) 

Logical Block Address 

(LSB) 

20-23 

(MSB) 

Expected Initial Logical Block Reference Tag 

(LSB) 

24-25 

(MSB) 

Expected Logical Block Application Tag 

(LSB) 

26-27 

(MSB) 

Logical Block Application Tag Mask 

(LSB) 

28-31 

(MSB) 

Transfer Length 

(LSB) 


The WRITE command requests that the drive write data transferred from the initiator to disk. Each logical block 
transferred includes user data and may include protection information, based on the WRPROTECT field and the drive 
format. Each logical block written includes user data and, if the drive is formatted with protection information enabled, 
protection information. 

If the drive is formatted with type 2 protection (PROT_EN=1 and P_TYPE=001b in the READ CAPACITY (16) 
parameter data), then this command will be processed normally. Any other protection types will result in Check 
Condition status to be returned with sense key of Illegal Request and additional sense code of Invalid Command 
Operation Code 

The Expected Initial Logical Block Reference Tag field contains the value of the Logical Block Reference Tag field 
expected in the protection information of the first logical block accessed by the command. 

If the ATO bit is set to one in Mode Page OAh, the Logical Block Application Tag Mask field contains a value that is a 
bit mask for enabling the checking of the Logical Block Application Tag field in the protection information for each 
logical block accessed by the command. A Logical Block Application Tag Mask bit set to one enables the checking 
of the corresponding bit of the Expected Logical Block Application Tag field with the corresponding bit of the Logical 
Block Application Tag field in the protection information. 

If the ATO bit is set to zero, the Logical Block Application Tag Mask field and the Expected Logical Block Application 
Tag field are ignored. 
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8.57 WRITE AND VERIFY (10) - (2E) (Not supported) 


Table 266 WRITE AND VERIFY (10) - (2E) 



Bit 


6 

5 

4 

3 2 

1I^X 

0 

0 

Command Code = 2Eh 

1 

wrprotect\^ 

DPO 

\_ 


Byte 

Chk 

Obsolete 

2-5 

(MSB) 

LpgfcaTBlQck Address 

(LSB) 

6 

Reserved = 0 

7-8 

(MSB) 

Transfer Length X. 

/X (LSB) 


vu = o 

Reserved = 0 

FLAG 

LlhlK^ 


Cold storage product does not support write and verify command. When the drive receives write and verify command 
from the host, the drive will abort the command. 

WRITE AND VERIFY command requests that the drive writes the data transferred from the Initiator to the medium 
and then verify that the data is correctly written. If caching is enabled, an implied FUA (Force Unit Access) and an 
implied Synchronize Cache are performed before starting the operation. This insures that data from the disk, not 
the cache, is verified. 

• See the WRITE (10) command description for the definition of the WRPROTECT field. 

• Transfer Length is the number of contiguous blocks to transferred. If the transfer length is zero, the seek 
occurs, but no data is transferred. This condition is not considered an error. 

If caching is enabled, the command performs an implied FUA and an implied Synchronize Cache before starting 
the operation. This insures that the medium, not the cache, is being verified. 

• ByteChk bit set to zero indicates that the data is read back from the disk and verified using LDPC after the 
successful write operation. If an LDPC error is detected in the verify process, Check Condition status is returned 
with sense key set to Medium Error. ByteChk bit set to one indicates that byte-by-byte comparison is performed 
between data on the disk starting the block specified in LBA field and data transferred from the Initiator. 

If the comparison is unsuccessful, the command is terminated with Check Condition status and the sense key 
is set to Miscompare. 

• DPO (Disable Page Out) bit of one indicates that the data written by this command is to be assigned the lowest 
priority for being written into or retained by the cache. A DPO bit of one overrides any retention priority specified 
in the Mode Select Page 8 Caching parameters. A DPO bit of zero indicates the priority is determined by the 
retention priority. 

The Initiator should set the DPO bit when the blocks written by this command are not likely to be read again in 
the near future. 
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8.58 WRITE AND VERIFY (12) - (AE) (Not supported) 



Cold storage product does not support write and verify command. When the drive receives write and verify command 
from the host, the drive will abort the command. 

The WRITE AND VERIFY command requests that the drive write the data transferred from the Initiator to the medium 
and then verify that the data is correctly written. See the WRITE AND VERIFY (10) description for the definitions of 
the fields in this command. 
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8.59 WRITE AND VERIFY (16) - (8E) (Not supported) 


Table 268 WRITE and VERIFY (16) - (8E) 


^Byte\ 

Bit 

6 

5 

4 

3 2 

^X 

0 

0 

Command Code = 8Eh 

1 

WRPROTEfrk^^ 

DPO 

^R^served^= 0 

Byte 

Chk 

Obsole 

te 

2-9 

(MSB) 

LpglcaTBlQck Address 

(LSB) 

10-13 

(MSB) s' N. 

s' Transfer Length 

(LSB) 

14 

Reserved = 0 

X 

vu = o 

Reserved = 0 

FLAG 



Cold storage product does not support write and verify command. When the drive receives write and verify command 
from the host, the drive will abort the command. 

The WRITE AND VERIFY command requests that the drive write the data transferred from the Initiator to the medium 
and then verify that the data is correctly written. 
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8.60 WRITE AND VERIFY (32) - (7F/0C) (Not supported) 


Table 269 WRITE and VERIFY (32) • (7F/0C) 


X Byfe x 

Bit 

X 7 6 

5 

4 

3 2 

1 

yA 

0 

^X^ Command Code = 7Fh y/ 

i 

VU^0^ 

Reserved = 0 

j^Cg 

LINK 

2-5 

''X^ Reserved = 0 y/ 

6 

Reserved = 0 N \^ 

^Group Number = 0 

7 

'Adstitional CD^Length = 18h 

8-9 

ServjX/V 

ction = OOOCh 

10 

WRPROTECT ^ 

Xdpo 

Reserved = 0 

ByteChk 

Reserved=0 

11 

y/ Reserved = oX^ 

12-19 

y/ Logical Block Address 

20-23 

Expected Initial Logical Block Reference TagN^ 

24-25 

y/ Expected Logical Block Application 'X s ^ 

26-27/ 

Logical Block Application Tag Mask X^ 

^26-31 

Transfer Length 


Cold storage product does not support write and verify command. When the drive receives write and verify command 
from the host, the drive will abort the command. 

The WRITE AND VERIFY command requests that the drive write the data transferred from the initiator to disk and 
then verify that the data is correctly written. 

If the drive is formatted with type 2 protection (PROT_EN=1 and P_TYPE=001b in the READ CAPACITY (16) 
parameter data), then this command will be processed normally. Any other protection types will result in Check 
Condition status to be returned with sense key of Illegal Request and additional sense code of Invalid Command 
Operation Code 

The Expected Initial Logical Block Reference Tag field contains the value of the Logical Block Reference Tag field 
expected in the protection information of the first logical block accessed by the command. 

If the ATO bit is set to one in Mode Page OAh, the Logical Block Application Tag Mask field contains a value that is a 
bit mask for enabling the checking of the Logical Block Application Tag field in the protection information for each 
logical block accessed by the command. A Logical Block Application Tag Mask bit set to one enables the checking 
of the corresponding bit of the Expected Logical Block Application Tag field with the corresponding bit of the Logical 
Block Application Tag field in the protection information. 

If the ATO bit is set to zero, the Logical Block Application Tag Mask field and the Expected Logical Block Application 
Tag field are ignored. 
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8.61 WRITE BUFFER (3B) 


Table 270 WRITE BUFFER (3B) 


Byte 

Bit 

7 6 

5 

4 3 2 

1 

0 

0 

Command Code = 3Bh 

1 

Reserved = 0 

Mode 

2 

Buffer ID 

3-5 

Buffer Offset 

6-8 

Parameter List Length 

9 

vu = o 

Reserved = 0 

FLAG 

LINK 


The WRITE BUFFER command is used in conjunction with the READ BUFFER command as a diagnostic function 
for testing the memory of the drive and the SCSI bus integrity. This command does not alter the medium of the drive. 
Additional modes are provided fordownloading microcode and saving microcode. 

This command will cause the entire cache to be emptied. 

The function of this command and the meaning of fields within the command descriptor block depend on the contents 
of the mode field. 

Table 271 Mode 


MOD 

Description 

00000 

Write combined header and data 

00010 

Data 

00100 

Download Microcode 

00101 

Download Microcode and Save - single binary file 

00111 

Download Microcode and Save - multiple binary files 

01010 

Write Data to Echo Buffer 

OHIO 

Download microcode with offsets, save, and defer activate 

01111 

Activate deferred microcode 

11010 

Enable expander Communications Protocol 

All Others 

Not Supported 


If any values other than shown above are specified, Check Condition status is returned with a sense key of Illegal 
Request and additional sense code of Invalid Field in CDB. 
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8.61.1 Combined Header And Data (Mode 00000b) 

In this mode, the data to be transferred is preceded by a four-byte header. 

Buffer ID must be zero. If another value is specified, no download function is performed and the command is 
terminated with Check Condition status. And the drive shall set the sense key to Illegal Request and additional 
sense code to Illegal Field in CDB. 

Buffer Offset must be zero. If another value is specified, no download function is performed and the command is 
terminated with Check Condition status. And the drive shall set the sense key to Illegal Request and additional 
sense code to Illegal Field in CDB. 

Parameter List Length specifies the number of bytes that shall be transferred during the DATA OUT phase. This 
number includes four bytes of header, so the data length to be stored in the drive buffer is transfer length minus four. 
If the length exceeds the buffer size, the command is terminated with Check Condition status. And the drive shall 
set sense key to Illegal Request and additional sense code to Illegal Field in CDB. A Parameter List Length of less 
than four (size of header) indicates no data is transferred. 

The 4-byte header consists of all reserved bytes. 


Table 272 Write Buffer Header 


Byte 

Bit 

7 

6 

5 

4 

3 

2 

1 

0 

0-3 

Reserved = 0 


8.61.2 Write Data (Mode 00010b) 

In this mode, the DATA OUT phase contains buffer data. 

Buffer ID must be zero. If another value is specified, no download function is performed and the command is 
terminated with Check Condition status. And the drive shall set the sense key to Illegal Request and additional sense 
code to Illegal Field In CDB. 

Buffer Offset specifies the offset of the memory space specified by the Buffer ID. The initiator should conform to the 
offset boundary requirements returned in the READ BUFFER descriptor. If the value exceeds the buffer specified, 
the command is terminated with Check Condition status. And the drive shall set the sense key to Illegal Request 
and additional sense code to Illegal Field In CDB. 

Parameter List Length specifies the Parameter List Length. It must be 

• less than the capacity of the buffer size after adding the Buffer Offset value and 

• on a sector boundary 

A Parameter List Length of zero indicates no data is to be transferred and command status is returned. 

If an invalid value is specified, the command is terminated with Check Condition status. And the drive shall set the 
sense key to Illegal Request and additional sense code to Illegal Field In CDB. 
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8.61.3 Download Microcode (Mode 00100b) 

NOTE: It is not expected that a customer will ever issue this format of the command. 

In this mode, the microcode is transferred to the control memory space of the drive. When downloaded, the drive will 
operate with the newly downloaded code immediately until the next power cycle. 

Buffer ID field is used to indicate which portion of the microcode image is being downloaded. The following Buffer 
IDs are supported by the Target: 

- OOh: Main Microprocessor Code 

- nnh: ID of Vendor Unique Reserved Area 

Any unsupported value for the Buffer ID will cause the command to terminate with Check Condition status. And the 
drive shall set the sense key to Illegal Request and additional sense code to Illegal Field In CDB. 

Buffer Offset must be zero. If an invalid value is specified, the command is terminated with Check Condition status. 
The drive shall set the sense key to Illegal Request and additional sense code to Illegal Field in CDB. 

Parameter List Length must be the size of the data set to be downloaded. It may also be set to OOOOh in which 
case no code is updated and command status is returned. If an invalid value is specified, the command is terminated 
with Check Condition status. And the drive shall set the sense key to Illegal Request and additional sense code to 
Illegal Field In CDB. 

This process generates a unit attention condition for MICROCODE HAS BEEN CHANGED for all Initiators except the 
one which sent the WRITE BUFFER command. Upon the completion of the WRITE BUFFER command the new 
microcode is immediately ready for operation. 

Note: The Download Microcode mode described in this specification is to indicate that the drive will accept a 
command with this mode, though it is not expected that a user will ever issue such a command. To use the write 
buffer command with this mode, a special microcode version is required from development. If such a microcode is 
released from development, then it will include appropriate instructions on the function of new microcode and its effect 
on the drive operations after download. 

8.61.4 Download Microcode and Save (Mode 00101b) -Single Binary File 

In this mode the data is transferred to the drive to save into the System reserved area on the disk. This is for functional 
upgrade and configuration change reflecting the user's requirements and the manufacturer’s reason or both, and it is 
stored in the media as a permanent copy. The newly downloaded code becomes effective after the drive issues and 
completes a self-initiated Power On Reset. 

Note: It requires up to 30 seconds to update the microcode including the Flash ROM update. 

Note: New code to be downloaded to the drive will be provided by development either by request of a customer for 
an additional function or as a result of a functional change by development. However please note that not all possible 
fixes or new functions can be applied to a drive in this manner and that there is a very high dependency on the level 
of ROM code contained within the drive. If an invalid code or a code not compatible with the ROM code is downloaded, 
the drive will usually reject this code and will continue normal operation. However there is a small possibility that an 
invalid code will be accepted. If this occurs, the unit usually becomes inoperable and will have to be returned to the 
manufacturer for recovery. 

Buffer ID field is used to indicate which portion of the microcode image is being downloaded. To download microcode, 
the buffer ID should be set to OOh. Other values are reserved for HGST development purposes only. 
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8.61.5 Download Microcode and Save (Mode 00111b) - Multiple Binary Files 

In this mode the target receives a segment of the binary microcode file. The Parameter List Length (segment length) 
of each segment shall be a multiple of 4K bytes. The total length of all segments received shall be equal to the total 
length of the binary microcode file. All segments must be sent in the proper sequential order. 

If an invalid Parameter List Length is specified, Check Condition status is returned with sense key of Illegal Request 
and additional sense code of Invalid Field in CDB. 

The first segment sent in this mode indicates, by default, the first segment of the binary microcode file. If a Check 
Condition status is returned in this mode, a Buffer ID == OOh in the subsequent Write Buffer command in this mode 
indicates the first segment of the binary microcode file. Otherwise the Buffer ID field is ignored. 

The Buffer Offset field is ignored. 

After all segments of the binary microcode file have been received, the drive behavior is the same as Download 
Microcode and Save (Mode 00101b) - Single Binary File. 

8.61.6 Write Data to Echo Buffer (Mode 01010b) 

In this mode the Target transfers data into the echo buffer. The echo buffer is assigned in the same manner by the 
Target as it would for a WRITE operation. Data will be sent aligned on 4-byte boundaries. 

Upon successful completion of a WRITE BUFFER command the data will be preserved in the echo buffer unless 
there is an intervening command to any logical unit, in which case it may be changed. 

8.61.7 Download microcode with offsets, save, and defer activate (Mode 
01110b) 

In this mode, microcode shall be transferred to the drive using one or more WRITE BUFFER commands, saved to 
nonvolatile storage, and considered deferred. 

The deferred microcode shall be activated and no longer considered deferred when one of the following occurs: 

a) a power on; 

b) a WRITE BUFFER command with the activate deferred microcode mode (OFh) is processed. 

c) a Self Initiated Reset occurs. 

8.61.8 Activate deferred microcode mode (Mode 01111b) 

In this mode, deferred microcode that has been saved using the download microcode with offsets, save, and defer 
activate mode, if any, shall be activated and no longer considered deferred. 

The BUFFER ID field, the BUFFER OFFSET field, and PARAMETER LIST LENGTH field shall be ignored in this 
mode. 

8.61.9 Enable Expander Communications Protocol (Mode 11010b) 

In this mode the drive behavior is the same as Write Data to Echo Buffer (Mode 0101b). 
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8.62 WRITE LONG (10) (3F) (Not supported) 



Cold storage product does not support write long command. When the drive receives write long command from the 
host, the drive will abort the command. 

The WRITE LONG command requests the drive to write one block of data transferred from the Initiator. 

The transfer data must include 

• User Data 

• 18 bytes of MEDC data 

All WRITE LONG commands will behave as if the WRJJNCOR bit was set with the exception of having the COR_DIS 
bit set. COR_DIS bit behavior will take precedence if both WRJJNCOR and COR_DIS bits are set. 

Parameters are 

• COR_DIS - correction disabled, bit 7 in byte 1. When this bit is set to one, the drive will mark the LBA as a 

pseudo unrecovered error with correction disabled. A subsequent read to this LBA would: 

a) Perform no error recovery on the block; perform no automatic reallocation of the affected logical blocks, 
including any automatic reallocation enabled by the Read-Write Error Recovery mode page; 

b) Not consider errors on the affected logical blocks to be informational exception conditions as defined in the 
Information Exceptions Control mode page (see SPC-4); 

c) not log errors on the affected logical blocks in the Error Counter log pages 

d) On a read to the LBA, return check condition status with the sense key set to Medium Error and the 
additional sense code set to read error marked bad by client. 

• WRJJNCOR - write uncorrectable, bit 6 in byte 1. If the CORJJIS bit is not set, the drive will behave in the 

following manor regardless of the state of this bit. The drive will create a pseudo unrecovered error with correction 

enabled. On following read commands to the LBA, the drive will: 

a) use our normal recovery procedures (which will end in a hard error); 

b) perform no automatic reallocation of the affected logical blocks, including any automatic reallocation 
enabled by the Read-Write Error Recovery mode page; 

c) consider errors on the affected logical blocks to be informational exception conditions as defined in the 
Information Exceptions Control mode page (see SPC-4); 

d) log errors on the affected logical blocks in the Error Counter log pages 

e) On a read to the LBA, return check condition status with the sense key set to Medium Error and the 
additional sense code set to read error marked bad by client. 

The error state for LBA written with the COR_DIS or WRJJNCOR bits set, will remain in effect until the LBA 
is rewritten by a write, write same, format, write long without CORJ3IS set, reassign or write verify command. 
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• Logical Block Address field specifies the logical block at which the write operation shall occur. 

• Byte Transfer Length. This field must specify the exact number of bytes of data available for transfer. If a non¬ 
zero byte transfer length does not match the available data length, the Target terminates the command with 
Check Condition status, then the sense key is set to Illegal Request, and an additional sense code is set to 
Invalid Field in CDB. The valid and ILI bits are set to one and the information field is set to the difference of the 
requested length minus the actual length in bytes. Negative values are indicated by two's complement notation. 

Write pointer that is used for checking sequential write will not be updated by this command. 
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8.63 WRITE LONG (16) - (9F) (Not supported) 


Table 274 WRITE LONG (9F) 


^Byte^ 

Bit 


6 

5 

4 3 2 


0 

0 

Command Code = 9Fh 

1 

COR_DIS 

WRJjfaSQR 

PBLOCK=0 

^/Service Action (11 h) 

2-9 

(MSB) 

Lbgical Blobk Address 

(lsb, 

10-11 

Reserved^! 

12-13 

(MSB) 

Byte Transfer Length 

(LSB) 

14 

Reserved = 0 


VU = 0 

Reserved = 0 

FLAG 

'u'NK^ 


Refer to Write Long (10) for field definitions. 

Cold storage product does not support write long command. When the drive receives write long command from the 
host, the drive will abort the command. 
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8.64 WRITE SAME (10) - (41) 


Table 275 WRITE SAME (41) 


Byte 

Bit 

7 6 

5 

4 3 

2 

1 

0 

0 

Command Code = 41 h 

1 

WRPROTECT 

Reserved = 0 

PBDATA=0 

LBDATA=0 

Obsolete 

2-5 

(MSB) 

Logical Block Address 

(LSB) 

6 

Reserved = 0 

7-8 

(MSB) 

Number of Blocks 

(LSB) 

9 

vu = o 

Reserved = 0 

FLAG 

LINK 


The WRITE SAME command instructs the Target to write a single block of data transferred to the Target from the 
Initiator to a number of sequential logical blocks. This command is useful for writing large data areas without sending 
all of the data over the SCSI bus. 

• See the WRITE (10) command description for the definition of the WRPROTECT field. 

• Logical Block Address specifies the address at which the write begins. The Number of Blocks specifies the 
number of contiguous blocks to be written. If the number is zero, all of the remaining blocks on the specified 
Logical Unit are written. 

• Number of Blocks specifies the number of contiguous blocks to be written. If the number is zero, all of the 
remaining blocks on the specified logical unit are written. 

• RelAdr (Relative Block Address) is not supported and must be set to be zero. 

The data for this command is not retained in the cache. 

Write pointer that is used for checking sequential write will be updated by this command. 
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8.65 WRITE SAME (16) - (93) 


Table 276 WRITE SAME (16) - (93) 


Byte 

Bit 

7 6 

5 

4 3 

2 

1 

0 

0 

Command Code = 93h 

1 

WRPROTECT 

Reserved = 0 

PBDATA=0 

LBDATA=0 

Obsolete 

2-9 

(MSB) 

Logical Block Address 

(LSB) 

10-13 

(MSB) 

Number of Blocks 

(LSB) 

14 

Reserved = 0 

15 

vu = o 

Reserved = 0 

FLAG 

LINK 


The Write Same command instructs the Target to write a single block of data transferred to the Target from the 
Initiator to a number of sequential logical blocks. This command is useful for writing large data areas without sending 
all of the data over the SCSI bus. See the WRITE(10) command description for the definition of the WRPROTECT 
field. 

Write pointer that is used for checking sequential write will be updated by this command. 
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8.66 

WRITE SAME (32) - (7F/0D) 


Table 277 

WRITE SAME (32) 

- (7F/0D) 


Byte 

Bit 

1 7 1 6 1 

5 1 4 1 3 1 2 1 1 ! 

0 | 

0 

Command Code = 7Fh 

1 

VU = 0 

Reserved = 0 FLAG 

LINK 

2-5 

Reserved = 0 

6 

Reserved = 0 

Group Number = 0 


7 

Additional CDB Length = 18h 

8-9 

Service Action = OOODh 

10 

WRPROTECT 

Reserved = 0 PBDATA=0 LBDATA=0 

Reserved =0 

11 

Reserved = 0 

12-19 

(MSB) 

Logical Block Address 

(LSB) 

20-23 

(MSB) 

Expected Initial Logical Block Reference Tag 

(LSB) 

24-25 

(MSB) 

Expected Logical Block Application Tag 

(LSB) 

26-27 

(MSB) 

Logical Block Application Tag Mask 

(LSB) 

28-31 

(MSB) 

Number of Blocks 

(LSB) 


The WRITE SAME command requests that the drive write a single block of data transferred from the initiator to disk 
for a number of sequential logical blocks. This command is useful for writing large data areas with the same data, 
without sending all of the data over the interface. Each logical block transferred includes user data and may include 
protection information, based on the WRPROTECT field and the drive format. Each logical block written includes 
user data and, if the drive is formatted with protection information enabled, protection information. 

If the drive is formatted with type 2 protection (PROT_EN=1 and P_TYPE=001b in the READ CAPACITY (16) 
parameter data), then this command will be processed normally. Any other protection types will result in Check 
Condition status to be returned with sense key of Illegal Request and additional sense code of Invalid Command 
Operation Code 

The Expected Initial Logical Block Reference Tag field contains the value of the Logical Block Reference Tag field 
expected in the protection information of the first logical block accessed by the command. 

If the ATO bit is set to one in Mode Page OAh, the Logical Block Application Tag Mask field contains a value that is a 
bit mask for enabling the checking of the Logical Block Application Tag field in the protection information for each 
logical block accessed by the command. A Logical Block Application Tag Mask bit set to one enables the checking 
of the corresponding bit of the Expected Logical Block Application Tag field with the corresponding bit of the Logical 
Block Application Tag field in the protection information. 

If the ATO bit is set to zero, the Logical Block Application Tag Mask field and the Expected Logical Block Application 
Tag field are ignored. 

Write pointer that is used for checking sequential write will be updated by this command. 
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9 SCSI Status Byte 

Upon the completion of a command a status byte is sent to the initiator. Additional sense information may also be 
available depending on the contents of the status byte. The following section describes the possible values for the 
status byte and sense data. All Reserved fields are set to zero. 

Table 278 Format of the SCSI STATUS byte. 


Bit 

7 

6 

5 

4 

3 

2 

1 

0 

Reserved = 0 

Status Code 

RSVD 


Table 279 SCSI Status Byte 


STATUS 

BYTE 

Description 

OOh 

GOOD 

The command has been successfully completed. 

02h 

CHECK CONDITION 

An error, exception, or abnormal condition has been detected. The sense data is set by the drive. The 
REQUEST SENSE command should be issued to determine the nature of the condition. 

04h 

CONDITION MET 

This status is returned when an unlinked PRE-FETCH command has been successfully completed. 

08h 

BUSY 

This condition is returned when disconnect privilege is not granted while the drive is BUSY processing 
the other command for the other initiator. The normal initiator recovery action is to issue the command 
at a later time or to reissue the command and grant the disconnect privilege. 

lOh 

INTERMEDIATE 

Not supported. 

14h 

INTERMEDIATE CONDITION MET 

Not supported. 

18h 

RESERVATION CONFLICT 

This status is returned whenever an SCSI device attempts to access the drive, but it has been reserved 
by another initiator. 

28 h 

QUEUE FULL 

This status indicates that the target's command queue is full. If a tagged command queuing feature is 
enabled and there is no room on the command queue, this status is returned when the initiator sends 
a command. For this status, sense data are not valid. 
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10 Additional information 

This chapter provides additional information or descriptions of various functions, features, or operating models 
supported by the Target that are not fully described in previous chapters. 


10.1 SCSI Protocol 

There are various operating conditions that prevent the Target from executing a SCSI command. This section 
describes each of these operating conditions and their relative priority. 

10.1.1 Priority of SCSI Status Byte Reporting 

After establishing the l_T_L nexus or l_T_L_Q nexus the Target must first determine whether command execution is 
allowed. Execution is deferred until a later time if the command must be added to the command queue. Execution 
may also be prevented by an internal Target condition that requires the reporting of a Check Condition, Queue Full, 
Busy, or Reservation Conflict Status. There are several different internal conditions to be active at the same time. 
The order in which the Target checks for each of these conditions determines their priority (highest priority first) as 
follows: 

1. Check Condition status for invalid Logical Unit Number. (See Section 10.1.2 "Invalid LUN Processing") 

2. Check Condition status for Incorrect Initiator Connection (See Section 10.1.3 "Overlapped Commands") 

3. Check Condition status for Unit Attention Condition (See Section 10.1.5 "Unit Attention Condition") 

4. Busy Status or Queue Full Status (See 10.1.4 "Command Processing During Execution of Active I/O Process") 

5. Check Condition status for Deferred Error Condition (See Section 10.1.8 “Deferred Error Condition”) 

6. Check Condition status during Startup and Format operations (See Section 0 “Command Processing During 
Startup and Format Operations”) 

7. Reservation Conflict status (See Section 10.1.10 “Command Processing while Reserved") 

8. Check Condition status for invalid command op code 

9. Check Condition status for invalid command descriptor block 

The highest priority internal condition that prevents command execution is reported by the Target provided there is 
no bus error. 

For all Check Conditions Sense data is built by the target provided a valid LUN address is known. Sense data is 
cleared by the Target upon receipt of any subsequent command to the LUN from the initiator receiving the Check 
Condition. 

10.1.2 Invalid LUN Processing 

Any value other than zero is invalid. 

The target's response to an invalid LUN varies with the command, as follows: 

Inquiry: Execute the command, return the INQUIRY data that indicates unknown device type (byte 0 = 7Fh), and 
return GOOD status. All other bytes are valid (see 8.5 "INQUIRY (12)"). 

Request Sense: Execute the command, return the sense data with the Sense Key set to Illegal Request and the 
Additional Sense Code and Additional Sense Code Qualifier set to LOGICAL UNIT NOT SUPPORTED, and return 
GOOD status (see also 8.37 "REQUEST SENSE (03)"). 

All Others: Do not execute the command and return CHECK CONDITION status, along with the auto-sense data 
with the Sense Key set to Illegal Request and the Additional Sense Code and Additional Sense Code Qualifier set to 
LOGICAL UNIT NOT SUPPORTED. 

In all cases, the target's response to the command for an invalid LUN does not affect the current execution of a 
command on the valid LUN for this initiator or any other initiator. 
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10.1.3 Overlapped Commands 

The drive does not perform any overlapped command checking. 

10.1.4 Command Processing During Execution of Active I/O Process 

When the target is not executing any I/O processes, a new I/O process is permitted to execute (unless execution is 
prevented by another internal target condition listed in 10.1.1 "Priority of SCSI Status Byte Reporting"). 

If an active I/O process exists when the target receives a new command, then the target determines if: 

• the command is permitted to execute 

• the command is added to the queue 

• Queue Full status is to be returned 

• Busy status is to be returned 

If an active I/O process exists when the target receives a new command, then the target determines how the new 
command should be handled based on the following rules: 

• Check Condition status is returned with sense key set to Logical Unit Not Ready if: 

• the startup operation or a format operation is active. See Command Processing During Execution of Active I/O 
Process for the exact conditions which cause this response. 

Note: If a Unit Attention is pending when this condition exists, the sense key is set to Unit Attention rather than Logical 
Unit Not Ready since Unit Attention has a higher reporting priority (see 10.1.4 "Command Processing During 
Execution of Active I/O Process") 

• The command is permitted to execute if: 

the command is a priority command (see Concurrent I/O Process the conditions to execute concurrently are met (see 
10.1.1 "Priority of SCSI Status Byte Reporting") 

The command is added to the queue if: 

• any I/O process already exists at the target, and 

• this is not an incorrect initiator connection. 

• Queue Full status is returned if: 

the command would otherwise be added to the queue (according to the rules described above), but all slots in the 
queue are full, or the command would otherwise be added to the queue (according to the rules described above), but 
all of the available queue slots not reserved for use by another initiator are full, or a Format Unit command was 
previously queued but has not yet begun execution, or the target is in a Degraded Mode (see "Degraded Mode") and 
a Start Unit command was previously queued but has not yet begun execution. 

• Busy status is never returned on SCSI or FCAL. BUSY status is returned on SAS if more than 64 unique Initiators 
send frames to the drive since the last POR. In that case, BUSY status in only returned for Initiators above and 
beyond the first 64. 
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10.1.5 Unit Attention Condition 

The target generates a unit attention condition when one of the following occurs: 

• The target has been reset 

This includes a power-on reset or a reset caused by a LUN Reset Task Management function or Hard Reset 
sequence. In all of these cases, a unit attention condition is generated for each initiator. 

• MODE SELECT command has been executed 

In this case, a unit attention condition is generated for all initiators except the one that issued the MODE SELECT 
command. The Additional Sense Code and Additional Sense Code Qualifier reported is MODE PARAMETERS 
CHANGED. The unit attention condition is generated if any of the current page parameters are set by the MODE 
SELECT command. The target does not check to see that the old parameters are different from the new 
parameters. For example: If the initiator issues a MODE SENSE command with a page code to report the current 
values followed by a MODE SELECT command with the same parameter list, a unit attention condition is 
generated despite the fact that the current parameters were not changed from their previous value. However, if 
the target detects an illegal parameter or error condition prior to modifying the current parameters, a unit attention 
condition is not generated since the parameters were not set. The unit attention condition is also not generated if 
the MODE SELECT command parameter list does not include any pages and only the header or header/block 
descriptor is present. 

• FORMAT UNIT command has been executed 

In this case, a unit attention condition is generated for all initiators except the one that issued the FORMAT UNIT 
command. The Additional Sense Code and Additional Sense Code Qualifier reported is NOT READY TO READY 
TRANSITION, (MEDIUM MAY HAVE CHANGED). This indicates that the block descriptor parameters from the 
last MODE SELECT command have been used and are now considered current values. 

• WRITE BUFFER command to download microcode has been executed 

In this case, a unit attention condition is generated for all initiators except the one that issued the WRITE BUFFER 
command. The Additional Sense Code and Additional Sense Code Qualifier reported is MICROCODE HAS BEEN 
CHANGED. 

• Commands Cleared by another initiator 

This unit attention condition is generated after an initiator sends a Clear Task Set Task Management function. The 
unit attention condition is generated for all other initiators with I/O processes that were either active or queued for 
the logical unit. The Additional Sense Code and Additional Sense Code Qualifier reported is COMMANDS 
CLEARED BY ANOTHER INITIATOR. 

• LOG SELECT command with PCR bit has cleared parameters. 

In this case, a unit attention condition is generated for all initiators except the one that issued the LOG SELECT 
command. The additional sense code and additional sense code qualifier reported is Log Select Parameters 
Changed. 

• The registration or reservation made by a Persistent Reserve Out command was cleared by another initiator. 

In this case, a unit attention condition is generated for the initiator that held the cleared registration or reservation. 

• A Predictive Failure Analysis threshold has been reached and the Method of Reporting field of mode page ICh is 
2h. 

The unit attention condition persists for each initiator until that initiator clears the condition from the logical unit as 
described below. Several commands are handled as special cases during a unit attention condition these cases are 
also discussed below. 

If the target receives a command from an initiator before reporting a CHECK CONDITION status for a pending unit 
attention condition for that initiator, the target's response varies with the command as follows: 
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Table 280 Response 


Inquiry 

Execute the command, return GOOD status, and preserve the unit attention condition. 

Report Luns 

Same as above 

Request Sense 

Execute the command, return any pending sense data, return GOOD status, and preserve 
the unit attention condition. If there is not any pending sense data, the sense data associated 
with the highest priority unit attention condition is returned and the highest priority unit 
attention condition is cleared for this initiator. 

All Others 

Do not execute the command, return a CHECK CONDITION status, clear the highest priority 
unit attention condition for this initiator and return the associated sense data. 

More than one unit attention condition may be generated for an initiator before that initiator 
clears the unit attention condition. 


10.1.6 Command Processing During Startup and Format Operations 

If the Target receives a command from an Initiator while the Target is executing a startup or format operation, the 
response of the Target varies with the command as follows: 


Table 281 Response 


INQUIRY 

The drive sends inquiry data and returns appropriate status. 

REQUEST SENSE 

Executes the command, returns a Sense key of NOT READY and an Additional Sense Code 
of LOGICAL UNIT NOT READY and returns GOOD STATUS. 

The Additional Sense Code Qualifier that is returned depends on type of I/O processes that 
are active: 

For the START/UNIT STOP and the Auto-start operation, the qualifier returned is LOGICAL 
UNIT IS IN PROCESS OF BECOMING READY. For the FORMAT UNIT command, the 
qualifier returned is LOGICAL UNIT NOT READY, FORMAT IN PROGRESS, and the Sense 
key specific bytes are set to return the progress indication. 

REPORT LUNS 

The drive sends REPORT LUNS data and appropriate status. 

ALL OTHER 

The drive terminates the command with CHECK CONDITION status. The Sense data 
generated is described in Request Sense above. 


10.1.7 Internal Error Condition 

The Target generates an Internal Error condition for all Initiators when an internally initiated operation ends with an 
unrecoverable error, that is, the startup sequence for Auto Start enabled terminates after the SCSI bus has been 
enabled and prior to completion of the bring-up sequence. 

An Internal Error condition causes Sense data to be generated and saved for all Initiators. The Error Code field of the 
Sense is set for a Current Error (70h or 72h) and the Sense Key is set to HARDWARE ERROR. Recovered errors 
are not reported. 

The Internal Error condition persists for each Initiator until that Initiator clears the condition from the logical unit as 
described below. Several commands are handled as special cases during an Internal Error condition. These cases 
are also discussed. 

If the Target receives a command from an Initiator while an Internal Error condition exists for that Initiator, the 
response of the Target varies with the command as follows: 


Table 282 Response 


INQUIRY 

The drive executes the command with GOOD status and does not clear the Internal Error 
condition. 

REQUEST SENSE 

The drive executes the command, returns the sense data generated by the Internal Error 
condition, returns Good Status, and clears the Internal Error condition for that Initiator. 

ALL OTHER 

The drive terminates the command with a CHECK CONDITION status and clears the 
Internal Error condition. 
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10.1.8 Deferred Error Condition 

Error code (71 h or 73h) of sense data indicates that the Check Condition status returned is the result of an error or 
exception condition that occurred during execution of a previous command for which Good status has already been 
returned. 

The drive creates an Deferred Error condition when 

• Execution of a Format Unit command with the immediate bit of one ends with an error. 

• Execution of a Write command with WCE (Write Cache Enable) bit of one ends with an error. 

10.1.9 Degraded Mode 

There are certain errors or conditions which may impair the ability of the drive to function normally. Rather than fail 
hard the drive is designed to be as responsive as possible. Also, in most cases, some action on the part of the initiator 
may be used to restore normal operation. This mode of limited operation is called Degraded Mode. 

There are 3 conditions in the Degraded Mode: 

• Spindle Motor Degrade which is caused by one of the following conditions: 

- Spindle Motor was started (by POR or Unit Start command) and the Target is under Self Configuration. 

- Spindle Motor Failed to start. 

- Spindle Motor was stopped by Unit Stop command after the Target successfully completed the Self 
Configuration. 

• Self Configuration Failure Degraded which is caused by one of the following conditions: 

- RAM Code, Configuration Sector Read Failure 

- RAM Code, Configuration Sector Revision Mismatch 

• Format Command Failure Degraded. This condition is caused when Format Unit command failed or was 
interrupted abnormally (Mode Page 0, byte 5, bit 4 FDD controls Format Degraded mode) 

10.1.9.1 Response to SCSI Command in Degraded Mode - Disable Auto 
Start 


The tables on the following pages show the degraded mode status with acceptable commands and additional sense 
codes 

Table 283 Spindle Motor Degraded Mode - Disable Auto Start 


Command (w/Option) 

Response 

Request Sense 

Executed. The Target may return Sense Key 02h (Not Ready) ASC/ASCQ 0402h 
(Initialize Command Required) 

Inquiry (EVPD=0) 

Executed 

Inquiry (EVPD=1) 

Executed and Check Condition is returned with Sense Key 05h (Illegal Request) 
ASC/ASCQ 2400h (Invalid Field in CDB) 

Test Unit Ready 

Executed and Check Condition is returned with Sense Key 02h (Not Ready) 
ASC/ASCQ 0402h (Initialize Command Required) 

Start Stop Unit (Start) 

Executed 

- Success: Good Status is returned. Motor Degraded Mode is cleared 

- Spindle Motor Start Failure: Check Condition with Sense Key 02h (Not Ready) 
ASC/ASCQ 0400h (Start Spindle Motor Fail) 

- Self Configuration Failure: Check Condition with Sense Key 02h (Not Ready) 
ASC/ASCQ 4080h (Diag Fail- Bring up Fail) 

Sense Key 02h (Not Ready) ASC/ASCQ 4085h (Diag Fail-RAM Code NOT load) 

Start Stop Unit (Stop) 

Executed. Good Status is returned. Motor Degraded Mode is NOT cleared 

Other Commands 

Not Executed. Check Condition Status is returned with Sense Key 02h (Not Ready) 
ASC/ASCQ 0402h (Initialize Command Required) 
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10.1.9.2 Response to SCSI Command in Degraded Mode - Auto Start Delay/ 
Spinning Up 


Table 284 Spindle Motor Degraded Mode - Auto Start Delay/Spinning Up 


Command (w/Option) 

Response 

Request Sense 

Executed. The Target may return Sense Key 02h (Not Ready) ASC/ASCQ 0401 h (In 
Process of Becoming Ready) 

Inquiry (EVPD=0) 

Executed 

Inquiry (EVPD=1) 

Executed and Check Condition is returned with Sense Key 05h (Illegal Request) 
ASC/ASCQ 2400h (Invalid Field in CDB) 

Test Unit Ready 

Executed and Check Condition is returned with Sense Key 02h (Not Ready) 
ASC/ASCQ 0401 h (In Process of Becoming Ready) 

Start Stop Unit 
(Start) 

Executed 

- Success: Good Status is returned. Motor Degraded Mode is cleared 

- Spindle Motor Start Failure: Check Condition with Sense Key 02h (Not Ready) 
ASC/ASCQ 0400h (Start Spindle Motor Fail) 

- Self Configuration Failure: Check Condition with Sense Key 02h (Not Ready) 
ASC/ASCQ 4080h (Diag Fail- Bring up Fail) 

Sense Key 02h (Not Ready) ASC/ASCQ 4085h (Diag Fail-RAM Code NOT load) 

Other Commands 

Not Executed. Check Condition Status is returned with Sense Key 02h (Not Ready) 
ASC/ASCQ 0401 h (In Process of Becoming Ready) 


10.1.9.3 Response to SCSI Command in Degraded Mode - Spindle Start 
Failure 

Table 285 Spindle Motor Degraded Mode - Spindle Start Failure 


Command (w/Option) 

Response 

Request Sense 

Executed. The Target may return Sense Key 02h (Not Ready) ASC/ASCQ 0400h 
(Start Spindle Motor Fail) 

Inquiry (EVPD=0) 

Executed 

Inquiry (EVPD=1) 

Executed and Check Condition is returned with Sense Key 05h (Illegal Request) 
ASC/ASCQ 2400h (Invalid Field in CDB) 

Test Unit Ready 

Executed and Check Condition is returned with Sense Key 02h (Not Ready) 
ASC/ASCQ 0400h (Start Spindle Motor Fail) 

Start Stop Unit (Start) 

Executed 

- Success: Good Status is returned. Motor Degraded Mode is cleared 

- Spindle Motor Start Failure: Check Condition with Sense Key 02h (Not Ready) 
ASC/ASCQ 0400h (Start Spindle Motor Fail) 

- Self Configuration Failure: Check Condition with Sense Key 02h (Not Ready) 
ASC/ASCQ 4080h (Diag Fail- Bring up Fail) 

Sense Key 02h (Not Ready) ASC/ASCQ 4085h (Diag Fail-RAM Code NOT load) 

Start Stop Unit (Stop) 

Executed. Good Status is returned. Motor Degraded Mode is NOT cleared 

Other Commands 

Not Executed. Check Condition Status is returned with Sense Key 02h (Not Ready) 
ASC/ASCQ 0400h (Start Spindle Motor Fail) 
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10.1.9.4 Response to SCSI Command in Degraded Mode - Spindle Stopped 


by Unit Stop Command 

Table 286 Spindle Motor Degraded Mode - Spindle Stopped by Command 


Command (w/Option) 

Response 

Request Sense 

Executed. The Target may return Sense Key 02h (Not Ready) ASC/ASCQ 0402h 
(Initialize Command Required) 

Inquiry (EVPD=0) 

Executed 

Inquiry (EVPD=1) 

Executed 

Test Unit Ready 

Executed and Check Condition is returned with Sense Key 02h (Not Ready) 
ASC/ASCQ 0402h (Initialize Command Required) 

Start Stop Unit (Start) 

Executed 

- Success: Good Status is returned. Motor Degraded Mode is cleared 

- Spindle Motor Start Failure: Check Condition with Sense Key 02h (Not Ready) 
ASC/ASCQ 0400h (Start Spindle Motor Fail) 

- Self Configuration Failure: Check Condition with Sense Key 02h (Not Ready) 
ASC/ASCQ 4080h (Diag Fail- Bring up Fail) 

Sense Key 02h (Not Ready) ASC/ASCQ 4085h (Diag Fail-RAM code NOT load) 

Start Stop Unit (Stop) 

Executed. Good Status is returned. Motor Degraded Mode is NOT cleared 

Other Commands 

Not Executed. Check Condition Status is returned with Sense Key 02h (Not Ready) 
ASC/ASCQ 0402h (Initialize Command Required) 
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10.1.9.5 Self Configuration Failure Degraded Mode 


Table 287 Self Configuration Failure Degraded Mode 


Command (w/Option) 

Response 

Request Sense 

Executed. The Target may return 

Sense Key 02h (Not Ready) ASC/ASCQ 4080h (Diag Fail- Bring up Fail) 

Sense Key 02h (Not Ready) ASC/ASCQ 4085h (Diag Fail-RAM code NOT load) 

Inquiry (EVPD=0) 

Executed 

Inquiry (EVPD=1) 

Executed and Check Condition is returned with 

Sense Key 05h (Illegal Request) ASC/ASCQ 2400h (Invalid Field in CDB) 

Test Unit Ready 

Executed and Check Condition is returned with 

Sense Key 02h (Not Ready) ASC/ASCQ 4080h (Diag Fail- Bring up Fail) 

Sense Key 02h (Not Ready) ASC/ASCQ 4085h (Diag Fail-RAM code NOT load) 

Start Stop Unit 
(Start) 

Executed 

- Success: Good Status is returned. Motor Degraded Mode is cleared 

- Spindle Motor Start Failure: Check Condition with Sense Key 02h (Not Ready) 
ASC/ASCQ 0400h (Start Spindle Motor Fail) 

- Self Configuration Failure: Check Condition with Sense Key 02h (Not Ready) 
ASC/ASCQ 4080h (Diag Fail- Bring up Fail) 

Sense Key 02h (Not Ready) ASC/ASCQ 4085h (Diag Fail-RAM code NOT load) 

Write Buffer 
(Download and Save) 

Executed. 

- Success: Good Status is returned. Motor Degraded Mode is cleared 

- Self Configuration Failure: Check Condition with Sense Key 02h (Not Ready) 
ASC/ASCQ 4080h (Diag Fail- Bring up Fail) 

Sense Key 02h (Not Ready) ASC/ASCQ 4085h (Diag Fail-RAM code NOT load) 

Other Commands 

Not Executed. Check Condition Status is returned with 

Sense Key 02h (Not Ready) ASC/ASCQ 4080h (Diag Fail- Bring up Fail) 

Sense Key 02h (Not Ready) ASC/ASCQ 4085h (Diag Fail-RAM code NOT load) 
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10.1.9.6 Format Command Failure Degraded Mode 


Table 288 Format Command Failure Degraded Mode 


Command (w/Option) 

Response 

Request Sense 

Executed. The Target may return 

Sense Key 02h (Not Ready) ASC/ASCQ 3100h (Format Corrupted) 

Sense Key 03h (Medium Error) ASC/ASCQ 3100h (Format Corrupted) 

Inquiry (EVPD=0) 

Executed 

Inquiry (EVPD=1) 

Executed 

Test Unit Ready 

Executed and Check Condition is returned with Sense Key 02h (Not Ready) 
ASC/ASCQ 3100h (Format Corrupted) 

Format Unit 

Executed 

- Success: Good Status is returned. Format Degraded Mode is cleared 

- Failure: Check Condition Status is returned and Format Degraded Mode is NOT 
cleared. 

Other Commands 
(read and write) 

Not Executed. Check Condition Status is returned with Sense Key 03h (Medium Error) 
ASC/ASCQ 3100h (Format Corrupted) 

Non-read/write commands will execute so the drive is as responsive as possible and 
for restoring normal operation. 


Note: Mode Page 0 byte 5 bit 4 (FDD) = 0 

Note: See also Section 10.1.9 "Degraded Mode" and Section 8.4 "FORMAT UNIT (04)". 


10.1.10 Command Processing while Reserved 

A logical unit is reserved after successful execution of the Reserve command. Each time a Reserve command is 
executed successfully, the Target records the SCSI ID of the Initiator that made the reservation and the SCSI ID of 
the Initiator that is to receive the reservation. This information is needed to determine whether subsequent commands 
should be permitted or if the Reservation Conflict Status should be reported. The Initiator that made the reservation 
is the Initiator that issued the Reserve command. The Initiator to receive the reservation may be either the same or a 
different Initiator (third-party reservation). 

If the logical unit is reserved when a new command is received, the Target examines the command opcode and the 
SCSI ID of the issuing Initiator to determine whether a Reservation Conflict Status should be returned based on the 
following rules: 

If the issuing Initiator is the one that made the reservation and also the one to receive the reservation, then all 
commands are permitted. 

If the issuing Initiator is neither the one that made the reservation nor the one to receive the reservation, then 

- A Request Sense or Inquiry command is permitted. 

- A Release command is permitted but is ignored. 

- Any other command results in a Reservation Conflict Status. 

If the issuing Initiator is the one that made the reservation but is not the one to receive the reservation, then 

- An Inquiry, Request Sense, Reserve, or Release command is permitted. 

- Any other command results in a Reservation Conflict Status. 

If the issuing Initiator is not the one that made the reservation but is the one to receive the reservation, then 

- A Reserve command results in a Reservation Conflict Status. 

- A Release command is permitted but is ignored. 

- Any other command is permitted. 

If a Reservation Conflict Status is not reported and the command is permitted, then the Target checks the next highest 
priority internal condition to determine whether execution is allowed. See Section 10.1.1 "Priority of SCSI Status Byte 
Reporting" 


HGST Hard Disk Drive OEM Specification 
260 




10.2 Priority Commands 

Certain SCSI commands always execute without returning a Busy Status or Reservation Conflict Status in response 
to the command. These commands are 

• Inquiry 

• Request Sense 

• Report LUNs 

• Test Unit Ready 

These commands are executed prior to attempting to complete the execution of any other pending command in the 
queue. These commands are never queued. 


10.3 Command Queuing 

When the initiator specifies that the drive shall disable command queuing, the initiator must send only untagged 
commands. When the initiator specifies that the target shall enable command queuing, the initiator may send either 
tagged or untagged command, but shall not use both at the same time. 

The following commands are never queued. 

• Priority Commands (i.e.: Request Sense and Inquiry) 

• Commands for an invalid LUN. 

10.3.1 Queue Depth 

Any initiator can queue at least one command at any time irrespective of the actions of any other initiators in the 
system. A single initiator may queue up to 128 commands, if no other initiator has more than one command in the 
queue, although at times this maximum may be reduced as the drive can reserve command blocks for internal use. 

10.3.2 Queue Full Status 

The drive will respond with QUEUE FULL status to a SCSI command when all queue slots are utilized. The SCSI 
command is not placed in the command queue under this condition. 

10.3.3 Termination of I/O Processes 

Normal termination of I/O processes occurs when the target returns SCSI status. I/O processes may also be 
terminated by the following: 

• An ABORT TASK terminates the specified I/O process from the issuing initiator 

• An ABORT TASK SET terminates all I/O processes from the issuing initiator 

• A CLEAR TASK SET, TARGET RESET or reset terminates all I/O processes from all initiators 
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10.4 Command Reordering 

Command reordering is supported when enabled by the Queue Algorithm Modifier in mode page 0A (see 8.11.9 
"Mode Page 0A (Control Mode Page Parameters)”. 


10.5 Concurrent I/O Process 

Concurrent command are always allowed to execute concurrently with non-priority commands. A second priority 
command received while a priority command is being executed is put at the head of the command queue. 

• WRITE commands when another WRITE command is an active I/O process 

• READ commands when another READ command is an active I/O process 

When a concurrent command ends in CHECK CONDITION status, the QErr bit on the Mode Page OAh will determine 
how other active I/O processes from the same initiator for that drive will be handled. 


10.6 Write Cache 

If the WCE (Write cache enable) bit is 1, the drive returns Good Status and closes the connection immediately after 
receiving the data of the last sector before actually writing the data onto the media. 

If the drive detects an error after it returns a Good Status, the drive sets a Deferred Error (Error Code of sense data 
= 71 h) and a following command will be returned with Check Condition and the Contingent allegiance condition is 
established. Under the Contingent allegiance condition all queued processes including commands from other 
initiators are suspended. 


10.7 Automatic Rewrite/Reallocate 

The target supports Auto and Recommended Reallocate for READ, WRITE, WRITE VERIFY, and VERIFY. 
Automatic and Recommend Reallocate operate from within the read/write command. When an automatic reallocation 
occurs, the read or write command takes longer to complete. 

This operation is sometimes referred to as auto-reassignment due to its similarity to the operation performed by the 
reassign command. 

Following is a description of the target behavior for each setting of ARRE. ARRE setting affects all data errors. (No 
Sector Found, Data Sync Byte Errors and Data LDPC Errors.) 

ARRE=1 : An error site determined to need rewriting or reallocation during a read is automatically rewritten or 

reallocated at the conclusion of the read and prior to the sending of the status. The site will be 
automatically rewritten or reallocated only if the data has been successfully read. 

ARRE=0: An error site determined to need rewriting or reassignment during a read is recommended for rewriting 

or reassignment at the conclusion of the read. 

The setting of the ARRE bit is checked and the target will automatically rewrite/reallocate or recommend 
rewrite/reassign for the following commands. 

• Read 

• Write 

For all other commands the ARRE setting is ignored and the target will not automatically rewrite/ reallocate or 
recommend rewrite/reassign. 

Following is a description of the target behavior for each setting of AWRE. AWRE setting affects only No Sector 
Found Errors on writes. 

AWRE=1: An error site determined to need reassignment during a write is automatically reallocated at the 

conclusion of the write and prior to sending the status. The site will be automatically reallocated only if 
the write recovery succeeded at the conclusion of the write. 

AWRE=0: An error site determined to need reassignment during a write is recommended for reassignment at the 

conclusion of the write. 
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The setting of the AWRE bit is checked and the target will automatically reallocate or recommend reassign for the 
following commands. 

• Write(6) 

• Write(IO) 

• Write portion of Write and Verify 

For all other commands the AWRE setting is ignored and the target will not automatically reallocate or recommend 
reassign. 

Auto/Recommend Reallocate information is communicated via the sense data returned following a command during 
which a site was determined to need rewriting or reassignment. The LBA returned in the sense data is the LBA that 
was determined to need rewriting or reassignment. 

The sense data combinations with auto/recommend rewrite/reallocate are listed below. 

Table 289 Sense data combinations with auto/recommend rewrite/reallocate 


Key 

Code 

Qual 

Description 

1 

17 

01 

Recovered Data with retries 

1 

17 

06 

Recovered Data without LDPC - Auto Reallocated 

1 

17 

07 

Recovered Data without LDPC - Recommend Reassign 

1 

17 

09 

Recovered Data without LDPC - Data Rewritten 

1 

18 

00 

Recovered Data with LDPC 

1 

18 

02 

Recovered Data with LDPC - Auto Reallocated 

1 

18 

05 

Recovered Data with LDPC - Recommend Reassign 

1 

18 

07 

Recovered Data with LDPC - Data Rewritten 
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10.8 Segmented Caching 

10.8.1 Overview 

Segmented Caching divides the data buffer into several smaller buffers. Each buffer is used as Read/ Write/Read- 
Ahead buffer. 

10.8.2 Read Ahead 

The Read Ahead function consists of reading data that the Initiator has not yet requested to the drive buffer. This 
function is intended to improve performance for an initiator that frequently accesses sequential data with successive 
SCSI read commands. The Read Ahead function works when RCD (the read cache disable) bit of read cache page 
(page 08h) is set to zero. 

The drive initiates the Read ahead function when the following conditions exist: 

• RCD is 0 

• Read, Verify and Write and Verify is received. 

• The consecutive LBA of the requested LBA is not available in the buffer 

If SCSI reset or target reset message is received, all contents of segmented buffer is flushed. 

Even if an error occurs during the Read ahead, the error will not be reported to the Initiator. The data read before the 
error occurred will be stored as valid data by the Read Ahead function. 


10.9 Multiple Initiator Systems 

This section describes how the target behaves in a multiple initiator system. Up to 64 initiators may be supported at 
any one time. 

10.9.1 Sense Data 

A separate sense data area is reserved for each initiator. Each area is maintained independently. This allows a 
command from one initiator to complete with a CHECK CONDITION status and generate sense data without being 
affected by a subsequent command from a different initiator. There is no requirement for the first initiator to send a 
REQUEST SENSE command to retrieve the Sense Data prior to the execution of a command from a different initiator. 

10.9.2 Mode Pages 

A single set of Mode pages is maintained. This includes both current and saved parameters. If a MODE SELECT 
command is executed that updates the current parameters, a unit attention condition is generated for all initiators 
except the one that issued the command. See 10.1.5 "Unit Attention Condition" for more information. 


10.10 Multiple Initiator Environment 

10.10.1 Initiator Sense Data 

Separate sense data is reserved for each l-T-L. Each sense data is maintained independent of commands from other 
initiators. 

10.10.2 Initiator Mode Select/Mode Sense Parameters 

A single shared copy of the Mode Select/Mode Sense parameters is maintained by the drive. This includes both the 
current and saved parameters. 
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10.11 Reset 

Reset actions will return the drive to a known, initialized state. 

This device supports the Hard reset option as defined in the SCSI standards and the reset sources discussed below. 

10.11.1 Initiator Sense Data 

There are four sources of resets detected by the target: 

Table 290 Reset 


Reset Name 

Reset Source 

Power-On Reset 

This is the signal generated by the hardware at initial power-on 

Self-Initiated reset 

This is a software-generated reset that occurs when a catastrophic error is detected by the 
microcode. 

Hard Reset 

This is the Hard Reset performed during a Link Reset Sequence. 

LUN Reset 

This is a LUN RESET TMF (08h) sent in a TASK IU. 


10.11.2 Reset Actions 

The action taken by the drive following a reset is dependent on the source of the reset. 

10.11.2.1 Power-On reset and Self-Initiated reset 

These two reset conditions cause the following to be performed in the order shown: 

• A power-up sequence 

• A startup sequence is necessary to put the drive in a ready state 
These reset conditions cause the following actions: 

• If the reset occurs during the power-up sequence, the power-up sequence is re-started. 

• If the auto-start option is enabled and a start-up sequence has not yet completed, the start-up sequence is 
restarted. Note: The power-up sequence is not re-run, since it has already completed. 

• If the reset occurs while a physical sector is being written, the WRITE operation is disabled at the end of the 
current sector. The media is not corrupted if power is maintained to the end of the current sector. 
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10.12 Diagnostics 

The drive will execute Power on Diagnostics at power on time to assure the correct operation of the drive by validating 
components (ROM, RAM, Sector Buffer, EEPROM, HDC, Spindle Motor, Actuator), checking stored information in 
the Reserved Area and EEPROM, and verifying fault detects circuits. 

Self-test can be invoked by issuing a SEND DIAGNOSTIC command. 

10.12.1 Power on Diagnostics 

At power on time the following tests are executed: 

1. Validation of ROM and EEPROM 

2. RAM test for internal RAM 

3. Test and Initialize HDC registers 

4. RAM test for Sector Buffer 

5. Start Spindle Motor (if enabled) 

6. Calibration of Actuator 

7. Read/Write test for all Heads 

8. Validation of RAM code and data table (RDM, Log, Mode Page) from the Reserved Area 

If Auto spin up is disabled, steps 5 - 8 will be executed by the first START STOP UNIT command which has the Start 
bit set. 

Faults detected before successful completion of the HDC section could prevent the drive from responding to a 
selection. 

Faults detected after the successful completion of the HDC test section will be reported as CHECK CONDITION 
status to the Initiator on the first command issued after a fault is detected (except for the INQUIRY, REPORT LUNS 
and REQUEST SENSE commands). The INQUIRY, REPORT LUNS and REQUEST SENSE commands will always 
be responded with a GOOD status. Detecting a fault during power on will not terminate execution of the tests nor will 
it terminate the power on process. 

10.12.2 Self-test via SEND DIAGNOSTIC Command 

10.12.2.1 Default Self-test 

The default self-test is invoked by the SlfTst bit in the SEND DIAGNOSTIC command. The response is simply a 
GOOD status if the test is successful or a CHECK CONDITION status if the test fails. 

The following tests are performed by the default self-test (in the order defined): 

1. Spin check is to check if the spindle motor is running at the correct speed. 

2. Write, Read and Compare test is a disk read/write test. It writes data to a predefined location in the reserved 
area and then reads it back and validates the content. All heads are tested. 

3. Seek test is a servo test. It validates seeks to 256 random locations out of the full volume. 

10.12.2.2 Short and Extended Self-tests 

There are two other types of self-tests that may be invoked using the Function Code field in the SEND DIAGNOSTIC 
command: a short self-test and an extended self-test. The tests performed in the short and extended self-tests are 
described later. The time required by a logical unit to complete its extended self- test is specified in the Extended self¬ 
test Completion Time field in the Control Mode Page. The results of self-test can be retrieved via the LOG SENSE 
command for Log Page 10. 
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10.12.2.3 Self-test Modes 

There are two modes for short and extended self-tests: a foreground mode and a background mode. These modes 
are described in the following clauses. 

Foreground mode 

When the drive receives a SEND DIAGNOSTIC command specifying a self-test to be performed in the foreground 
mode, the drive will return status for that command after the self-test has been completed. While performing a self¬ 
test in the foreground mode, the drive will respond to all commands except INQUIRY, REPORT LUNS, and 
REQUEST SENSE with a CHECK CONDITION status, a sense key of NOT READY and an additional sense code of 
LOGICAL UNIT NOT READY - SELF-TEST IN PROGRESS. 

If the drive is performing a self-test in the foreground mode and a test error occurs, the drive will update the self-test 
results log page and report CHECK CONDITION status with a sense key of HARDWARE ERROR and an additional 
sense code of LOGICAL UNIT FAILED SELF-TEST. The application client may obtain additional information about 
the failure by reading the self-test results log page. 

An application client may terminate a self-test that is being performed in the foreground mode using an ABORT TASK, 
ABORT TASK SET, or CLEAR TASK SET task management function. If the drive receives an ABORT TASK, ABORT 
TASK SET, or CLEAR TASK SET task management function while performing a self-test in the foreground mode, it 
will abort the self-test and update the self-test results log page. 

Background mode 

When the drive receives a SEND DIAGNOSTIC command specifying a self-test to be performed in the background 
mode, the drive will return status for that command as soon as the command descriptor block has been validated. 
After returning status for the SEND DIAGNOSTIC command specifying a self- test to be performed in the background 
mode, the drive will initialize the self-test results log page as follows. The Function Code from the SEND DIAGNOSTIC 
command will be placed in the Function Code field in the log page. The self-test Results field shall be set to OFh. 
After the self-test results log page is initialized, the drive will begin the first self-test segment. 

While the drive is performing a self-test in the background mode, it shall terminate with a CHECK CONDITION status 
any SEND DIAGNOSTIC command it receives that meets one of the following criteria: 

a. The SlfTst bit is one 

b. The Function Code field contains a value other than 000b or 100b. 

When terminating the SEND DIAGNOSTIC command, the sense key shall be set to NOT READY and the additional 
sense code shall be set to LOGICAL UNIT NOT READY, SELF-TEST in PROGRESS. While performing a self-test 
in the background mode, the drive will suspend the self- test to service any other command other than SEND 
DIAGNOSTIC (with Function Code field set to 100b) WRITE BUFFER (with the mode set to any download microcode 
option), FORMAT UNIT and START UNIT STOP command. Suspension of the self-test to service the command will 
occur within 2 seconds. If SEND DIAGNOSTIC (with Function Code field set to 100b), WRITE BUFFER (with the 
mode set to any download microcode option), FORMAT UNIT or START UNIT STOP command is received, the drive 
will abort the self-test, update the self-test log, and service the command within two seconds after the command 
descriptor block has been validated. 

An application client may terminate a self-test that is being performed in the background mode by issuing a SEND 
DIAGNOSTIC command with the Function Code field set to 100b (Abort background self-test function). 

Elements common to foreground and background self-test modes 

The Progress Indication field returned in response to a REQUEST SENSE command may be used by the application 
client at any time during execution of a self-test to poll the progress of the test. While executing a self-test unless an 
error has occurred, the drive will respond to a REQUEST SENSE command by returning a sense key of NOT READY 
and an additional sense code of LOGICAL UNIT NOT READY - SELF-TEST IN PROGRESS with the sense key 
specific bytes set for progress indication. 

The application client may obtain information about the twenty most recently completed self-tests by reading the self¬ 
test results log page. This is the only method for an application client to obtain information about self-tests performed 
in the background mode. The default self-test results are not logged in the log page. 

Tests performed in the Short and Extended Self-test 

The following table defines the tests performed in the short and extended self test. They are defined by their segment 
number which is also used to report Self-Test Results, in Log Sense Page 10. Note that the only difference between 
the Short and the Extended tests, is the sequential verify test in segment 7h. Also note that either of these tests can 
be run in foreground or background mode as previously described. 
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Table 291 Short and Extended Self-Test Description 


Segment 

Number 

Short Self-Test 

Extended 

Self-Test 

Test Description 

1h 

Drive Ready Test 

Internal check to insure drive is “ready”, similar to a Test 
Unit Ready command. 

2h 

Drive Diagnostics 

This test is comprised of the Default Self Test as defined in 
Section 10.12.2.1 "Default Self-test" 

3h 

SMART 

Perform SMART testing and check results to ensure that 
SMART threshold criteria are not exceeded 

4h 

Low Level Format check 

Check to insure that the media is currently not in the MEDIA 
FORMAT CORRUPTED state. 

5h 

Physical Head Check 

Write/Read test on each head in a predefined location in 
the drive's Reserved Area of the disk. 

6h 

Random Verify 

Perform 4000 random verify operations and insure no 
uncorrectable errors. 

7h 

- Verify First 300MB 

- Verify Last 100 MB 

Verify 
all LBA’s 

Sequential verify operation. Ensure that no uncorrectable 
errors occur within the verify range. 

8h 

Recheck SMART 

Same as segment 4h. 


10.12.2.4 Background Medium Scan 

For a related function, see Mode Page 1C (Informational Exceptions Control). 
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10.13 Idle Time Function 

The drive periodically saves data in logs and S.M.A.R.T. counters in the reserved area of the disks. The information 
is used by the drive to support various SCSI commands and for the purpose of failure analysis. 


10.14 Command Time out Limits 

The 'Command Time-out Limits' are defined as the time period from the SCSI Arbitration phase through the SCSI 
Task complete message, associated with a particular command. 

The following times are for environments where Automatic Reallocation is disabled and there are no queued 
commands. 

10.14.1 Reassignment Time 

The drive should be allowed a minimum of 5 seconds to complete a “Reassign Blocks” command. 

10.14.2 Format Time 

Approximately 13.5 hours should be allowed for complete a "Format Unit" command when certification is disabled. 
Allow 27 hours when certification is enabled. If "Fast Format" is enabled via the FFMT bit in mode page OOh, allow 1 
minute for completion. 

10.14.3 Start/Stop Unit Time 

The drive should be allowed a minimum of 30 seconds to complete a “Start Stop Unit” command (with Immed bit = 
0). Initiators should also use this time to allow startup sequences initiated by auto start ups and “Start Stop Unit” 
commands (with Immed bit = 1) to complete and place the drive in a “ready for use” state. 

Note: A time-out of one minute or more is recommended but NOT required. The larger system time-out limit 
allows the system to take advantage of the extensive ERP/DRP that the drive may attempt in order to 
successfully complete the startup sequence. 

Note: For SAS devices a NOTIFY(Enable Spinup) primitive is required prior to actually starting to spin up the 
spindle motor (regardless of whether a Start Stop Command with the Start bit set, was received or not). 

10.14.4 Medium Access Command Time 

The time-out limit for medium access commands that transfer user data or non-user data or both should be a minimum 
of 30 seconds. These commands are 
Pre-Fetch 
Read 

Read Defect Data 
Seek 

Send Diagnostic (Function Code = 0) 

Read Long 
Write 

Write Buffer 
Write Same 
Verify 

Note: The 30-second limit assumes the absence of bus contention and data transfers of 64 blocks or less. This 
time should be adjusted for anticipated bus contention and if longer user data transfers are requested. 
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10.14.5 Time-out Limits for Other Commands 

The drive should be allowed a minimum of 5 seconds to complete these commands: 

Inquiry 
Log Select 
Log Sense 
Mode Select 
Mode Sense 

Persistent Reserve In/Out 

Read Buffer 

Read Capacity 

Read Long 

Release 

Request Sense 

Reserve 

Set/Report Device Identifier 
Start/Stop Unit (with Immed bit = 1) 

Synchronize Cache 
Test Unit Ready 

The command time-out for a command that is not located at the head of the command queue should be increased 
by the sum of command time-outs for all of the commands that are performed before it is. 
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10.15 Recommended Initiator ERP 


The Drive's design points for error reporting to the system assumes certain system action for the error return codes. 
These assumptions are: 

1. SCSI protocol will be the first priority in reporting errors. 

2. The system will maintain a log of all reported errors. 

3. System architecture should include all error handling recommendations made in this section. Deviations should 
have mutual agreement between Drive development and system integration. 

This section is directed toward documenting the assumptions made by the Drive that the system is expected to 
implement. The two error classes that the system should be concerned with are DATA and NON-DATA errors. 

Data errors are those errors that deal with the handling of data to and from the MEDIA and are identified by the 
Additional Sense Code contained in the sense data. The Additional Sense Codes for data errors are as follows: 

• OC - Write error 

• 11 - Unrecovered read error 

• 14 - No record found 

• 16 - Data Synchronization mark error 

• 17 - Recovered read error without LDPC correction 

• 18 - Recovered read error with LDPC correction 

Typically, data errors do not include positioning of the heads or the data path though the electronics. 

Non data errors are those errors that do not have a direct relationship with transferring data to and from the media. 
Non data errors can include data handling if the media is not associated with the error (that is, interface error). 

The system action assumed for each class of error is outlined here. 

10.15.1 Drive Service Strategy 

The Drive service strategy is defined so the customer will be able to use the system as soon after a failure is detected 
as possible. The first priority is to replace the entire drive to make the system operational with minimal service time. 
The service representative should: 

1. Back up all the customer data on this drive if possible 

2. Replace the complete drive 

3. Restore the customer data 

4. Return the drive to customer service 

10.15.2 Recommendations for System Error Log 

The system error log should contain information about the Drive error that will allow recovery actions. The system 
error logs should contain all the error information returned in the sense data. At a minimum, the following information 
about each error occurrence should be logged. 

• Valid bit and error code (Sense byte 0) 

• Sense Key (Sense byte 2) 

• Information bytes (Sense bytes 3 through 6) 

• Command specific information (Sense bytes 8 through 11) 

• Additional Sense Code (Sense byte 12) 

• Additional Sense Code Qualifier (Sense byte 13) 

• Field Replaceable Unit (Sense byte 14) 

• Sense Key Specific (Sense bytes 15, 16, and 17) 

• Vender Unique error information (Sense bytes 20 through 23) 
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10.15.3 Data Recovery Procedure 

Statistically, most data error activity is noise related and has nothing to do with defects in the media. It is wrong for 
the system to assume that every data error reported occurred because of a defect in the media. It is also wrong for 
the system to assume that every data error that occurred because of a media defect rendered the Drive unusable. 
Recurring data error activity at the same physical location is an indication of a problem. The problem can be due to a 
media defect or magnetic damage. A media defect is physical damage to the recording capability of the media while 
magnetic damage is a defect in the bit pattern written to the media. 

In both cases, the error can be corrected without replacing the unit. The physical sector may require relocation. The 
Drive determines the need to reassign a sector. The Mode Select Page 1 option bit ARRE (See Section 8.11.3 
"Mode Page 01 (Read/Write Error Recovery Parameters)”) set active allows the Drive to relocate recovered read data 
errors. Non recovered data errors or the ARRE bit being inactive will have additional sense codes returned to 
recommend reassignment of sectors. 

The need to reassign a sector should be infrequent. Sites not meeting error rate criteria are removed from use during 
SAT (Surface Analysis Test) in Drive manufacturing. With the exception of some early life SAT escapes (sites that 
were marginally missed during SAT), reassigning defective sectors should be rare. Frequent sector reassignment 
may be an (early) indication of another type of failure. Sector reassignments are monitored as part of the predictive 
failure analysis. When a threshold is exceeded, the Drive will notify the initiator that a scheduled service action is 
required. 

Drive soft error rates are based on extraneous random faults that are not predictable. Media defects discovered after 
the Drive completes manufacturing final test need to be relocated so that soft error rates are not influenced by 
predictable known error sites. Failure of the system to properly relocate defective media sites can have a direct 
influence on system throughput and drive error rates. 

10.15.3.1 Reassign a Physical Sector 

The Drive determines the need to reassign physical sectors based on error activity. Once a physical sector requires 
reassignment, the Drive will either reassign the physical sector, or recommend to the initiator that the LBA associated 
with the physical sector be reassigned. 

When the following Sense Key, Additional Sense Code, and Additional Sense Code Qualifier combinations are 
returned, the initiator should reassign the LBA reported at the next opportunity. 

Note: In Table 292, the Key, Code, and Qualifier fields are all hex values (i.e., Sense Key 1 is 1h, Sense Code 17 is 17h, etc.). 


Table 292 Recommend Reassign Errors 


Key 

Code 

Qual 

Description 

1 

17 

07 

Recovered Data without LDPC - Recommend Reassignment 

1 

18 

05 

Recovered Data with LDPC - Recommend Reassignment 


To reassign an LBA that has sense data recommending a reassignment, the initiator should: 

1. Attempt to recover the data from the sector being reassigned with a Read (08) or Read (28) command. 

2. Reassign the LBA using the Reassign Blocks (07) command. 

- If the reassignment completes successfully (Good Status), log the error in the system error log. 

- If the reassignment completes unsuccessfully (Check Condition Status), follow the procedure in Section 
10.15.3.3 “Reassign Blocks Recovery". 

3. Write the LBA that was reassigned. 
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10.15.3.2 Data Error Logging 

The Drive will report data errors to the initiator that do not require immediate action (successful auto reallocation, 
successful auto rewrite, or no action needed on this occurrence). The initiator should log these errors in the system 
error log. No other action is required. 

Table 293 Log Only Errors 


Key 

Code 

Qual 

Description 

1 

16 

00 

Data Synchronization Mark Error 

1 

17 

01 

Recovered Data with Retries 

1 

17 

06 

Recovered Data without LDPC - Auto Reallocated 

1 

17 

09 

Recovered Data without LDPC - Data Rewritten 

1 

18 

00 

Recovered Data with LDPC 

1 

18 

02 

Recovered Data with LDPC - Auto Reallocated 

1 

18 

07 

Recovered Data with LDPC - Data Rewritten 


10.15.3.3 Reassign Blocks Recovery 

The Drive provides the capability to remove media defects without reducing capacity. If the mode parameter bit ARRE 
is active, the Drive will automatically reallocate LBA's determined to be defective. For those LBA's where the error is 
unrecoverable or the initiator elects to not have the Drive automatically reallocate LBA's, the Drive will recommend 
reassignment of the LBA. 

Recovery from a failed reassignment consists of the following actions: 

• Updating the defect descriptor to remove the LBA's that have been successfully reassigned and then retry the 
Reassign Blocks command. The LBA contained in the Command Specific Information field of the Sense Data is 
the LBA in the first defect descriptor that was not reassigned because of the failure. If the command failed 
because of an unrecoverable read error other than those specified in the defect descriptor, add this LBA to the 
defect descriptor and retry the command. Refer to Section 8.29 "REASSIGN BLOCKS (07)", for additional 
information. 

• If the retried Reassign Blocks (07) command completes successfully, returning to normal processing. 

• If the retried Reassign Blocks (07) command fails, servicing the drive using the service guidelines recommended 
in Section 10.15.1 "Drive Service Strategy". 
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10.15.4 Non data Error Recovery Procedure 

The Drive will follow a logical recovery procedure for non data errors. The initiator options for non-data errors are 
limited to logging the error, retrying the failing command, or replacing the drive. 

These recovery procedures assume the initiator practices data back-up and logs errors at the system level for 
interrogation by service personnel. 

10.15.4.1 Drive Busy 

The Drive is busy performing an operation. This is not an error condition. The initiator can test for completion of 
the operation by issuing Test Unit Ready (00) (or media access) commands. 

• If the Test Unit Ready (00) (or media access) command completes with Check Condition Status then issue a 
Request Sense (03) 

- If the specified recovery procedure for the sense data is for a condition other than drive busy, follow the 
recovery procedure for the condition reported. 

- If the specified recovery procedure for the sense data is for a drive busy condition, then continue re-issuing the 
Test Unit Ready (00) and Request Sense commands for the duration of a media access time-out or until the 
drive returns Good Status. 

- If the drive has been busy for longer than the limit specified in Section 10.14, "Command Time out Limits" then 
service the drive using the service guidelines recommended in Section 10.15.1 "Drive Service Strategy" 
Otherwise return to normal processing. 

• If the Test Unit Ready (00) (or media access) command completes with Good Status, then return to normal 
processing. 

10.15.4.2 Unrecovered Drive Error 

The initiator should retry the failing command. 

1. If the retry of the failing command completes with Good Status or recovered Sense Key, follow the recovery 
procedure in Section 10.15.4.3 "Recovered Drive Error". 

2. If the retry of the failing command completes with hardware error sense, verify there is no outside cause (e.g., 
power supply) for the failure, then retry the failing command. 

a. If the retry of the failing command completes with Good Status, follow the recovery procedure in next Section 
10.15.4.3 "Recovered Drive Error". 

b. If the retry of the failing command completes with Recovered sense or Hardware error sense, then service 
the drive using the service guideline recommended in Section 10.15.1 "Drive Service Strategy". 

10.15.4.3 Recovered Drive Error 

The Initiator should log the error as soft with the recovery level. 
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10.15.4.4 Drive Not Ready 

The initiator should do the following: 

1. Issue a Start Stop Unit (IB) command. 

2. Verify that the drive comes ready within the time specified. 

3. If the drive fails to come ready within the specified time, service the drive using the service guidelines specified 
in Section 10.15.1 "Drive Service Strategy". 

4. Retry the failing command. 

a. If the failing command completes with Good Status, log the error as recovered. 

b. If the failing command completes with Not Ready sense, verify there is no outside cause (for example, the 
power supply). Then service the drive using the service guidelines specified in Section 10.15.1 "Drive 
Service Strategy". 

10.15.4.5 No Defect Spare 

Three conditions can cause this error: 

1. When the Reassign Blocks (07) command is issued and there are no spares available for the Drive to use for 
the relocation requested. 

2. When the Glist is full and the sector to be reassigned cannot be added. 

3. During a format operation, there was not enough space available to fulfill the spare requirement (Dlist is too 
large). 

Service the Drive following Section 10.15.1 "Drive Service Strategy". 

10.15.4.6 Degraded Mode 

Refer to Section 10.1.9 "Degraded Mode", for the definition of this state. There are three causes for entering degraded 
mode. In all cases the Sense Key is Not Ready. The causes are the following: 

1. Sense Code/Qualifier of Logical Unit Not Ready, initializing command required. The spindle motor not spinning 
or not at the proper speed. This may not be an error condition. The initiator should issue a Unit start (IB) 
command to start the spindle motor. If the Drive fails to come ready in the time specified in Section 10.14, 
"Command Time out Limits" service the drive using the service guideline recommended in Section 10.15.1 
"Drive Service Strategy". 

2. Sense Code/Qualifier of Diagnostic Failure. Failure of a Send Diagnostic self test, a start up sequence, or other 
internal target failures. 

- Failure of a send diagnostic self test or a start up sequence. 

This failure is the result of the diagnostics that are executed during power on or when the Send Diagnostic (ID) 
command is executed detecting a failure. As with the RAM code not loaded and the configuration data not 
loaded, the recovery is either a power cycle or issuing the Send Diagnostic (ID) command with the self test bit 
set active. 

Recovery for a failed Send Diagnostic (1D) is achieved in one of the following ways: 

Executing the Send Diagnostic (1D) command 
Power cycling the drive 

If the failure repeats, service the drive using the service guideline recommended in Section 10.15.1 "Drive 
Service Strategy". 

Recovery for a failed power up sequence is achieved in one of the following ways: 

Issuing a Unit start (1B) command 
Power cycling the drive. 

If the failure repeats, service the drive using the service guideline recommended in Section 10.15.1 "Drive 
Service Strategy". 

- Internal target failures 

The drive periodically adjusts the track following for each head to compensate for expansion and contraction 
of the disks due to temperature changes. If one of these adjustments fails, the drive will enter a degraded mode 
to prevent writing data off track. 
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Recovery of this condition is either a power cycle or successful completion of the Send Diagnostic (1D). Service 
the drive using the recommended service guidelines specified in Section 10.15.1 "Drive Service Strategy", if 
the power cycle or the Send Diagnostic (1D) command fail to complete successfully. 

3. Sense Code/Qualifier of Format Command Failed Format Unit (04), Sense Code/Qualifier of Medium Format 
Corrupted Reassign Failed Reassign Blocks (07) command, or an automatic reallocation failed or was 
abnormally terminated. 

Recovery from a failed Format Unit (04) is achieved by retrying the command. If the command fails a second 
time, service the drive following the procedure defined in Section 10.15.1 "Drive Service Strategy". 

If the above defined recovery procedures fail to clear the degraded mode condition, the Drive should be replaced. 
Follow the procedure in Section 10.15.1 "Drive Service Strategy", when replacing the drive. 

10.15.4.7 Reserved Area Hard Error 

Sectors found defective in the reserved area of the disk cannot be reassigned after the Drive leaves the factory. The 
data in the reserved area is not directly accessible by the initiator. For this reason, the reserved area has all data. 
A data error must occur in both copies of the data record before the Drive considers a reserved area read error. When 
this happens, the integrity of the drive is questionable. 

Service the Drive using Section 10.15.1 "Drive Service Strategy". 

10.15.4.8 Interface Protocol 

For all interface protocol errors, the initiator should complete the following steps: 

1. Correct the parameter that caused the Illegal Request 

2. Retry the failing command 

3. If the first retry of the failing command completes with 
Good Status, log the error as recovered 

Check Condition Status with sense data for an Illegal Request, verify there is no outside cause (for example, 
the power supply) for the failure 

Other, follow the recommendations for the error condition reported. Retry the failing command. If this retry of 
the failing command completes with 

• Good Status, log the error as recovered 

• Check Condition Status with sense data for an Illegal Request, service the drive using the service guideline 
recommended in Section 10.15.1 "Drive Service Strategy". 

• Other, follow the recommendations for the error condition reported. 

10.15.4.9 Aborted Command 

The initiator should determine the cause from the Additional Sense Code (byte 12): 

• Sense Key = B (Aborted Command) with Additional Sense Codes of 1B, 25, 43, 49, and 4E are initiator caused 
abort conditions. The initiator should correct the condition that caused the abort and retry the failing command. 

• Sense Key = B (Aborted Command) with Additional Sense Code of 44 or 48 are drive caused abort conditions. 
The initiator should: 

1. Retry the failing command. 

2. If the retry of the failing command completes with 

- Good Status, log the error as recovered. 

- Abort Command Sense, verify there is no outside cause (e.g. power supply) for the failure. 

3. Retry the failing command. 

4. If the retry of the failing command completes with 

- Good Status, log the error as recovered. 

- Abort command sense, then service the drive using the service guideline recommended in Section 10.15.1 
"Drive Service Strategy". 

• Sense Key = B (Aborted Command) and an Additional Sense Code of 47 can be an initiator or Drive caused 
abort condition. The initiator should follow the above procedure for initiator caused abort conditions if the Drive 
detected the SCSI bus parity error. The initiator should follow the above procedure for Drive caused abort 
conditions if the initiator detected the SCSI bus parity error. 
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10.15.4.10 Unit Attention Condition 

Unit Attention Conditions are not errors. They alert the initiator that the drive had an action that may have changed 
an initiator controlled state in the drive. These conditions are the following: 

Not Ready to Ready Transition 

Not ready to ready transition, unit formatted. This Unit Attention Condition will not be reported to the initiator that 
issued the Format Unit (04). 

Reset 

Reset - This means the drive was reset by either a power-on reset, Hard Reset, LUN Reset TMF or an internal reset. 

Mode Parameters Changed 

A Mode Select (15) command successfully completed. This means that the mode parameters that are the current 
value may have changed. The parameters may or may not have changed but the command to change the parameters 
successfully completed. The Drive does not actually compare the old current and the new current parameters to 
determine if the parameters changed. This Unit Attention Condition will not be reported to the initiator that issued the 
Mode Select (15). 

Microcode Has Changed 

Write Buffer (3B) to download microcode has successfully completed. This means that the microcode that controls 
the Drive has been changed. The code may or may not be the same as the code currently being executed. The Drive 
does not compare old level code with new code. 

Commands Cleared by Another Initiator 

Tagged commands cleared by a clear queue message. This means that the command queue has been cleared. The 
Unit Attention Condition is not reported to the initiator that issued the clear queue message. Unit Attention Condition 
is reported to all initiators that had commands active or queued. 

Reissue any outstanding command. 

Log Select Parameters Changed 

A Log Select (4C) command successfully completed. This means that the Log Select command cleared statistical 
information successfully (See Section 8.7 "LOG SELECT (4C)"). Unit Attention Condition is reported to all initiators 
excluding the initiator that issued the Log Select command. 

Device Identifier Changed 

A Set Device Identifier (A4) command successfully completed. This means that the Set Device Identifier information 
field has been updated. (See 8.43 ’’SET DEVICE IDENTIFIER (A4/06)”) A Unit Attention Condition is reported to all 
initiators excluding the initiator that issued the Set Device Identifier command. 

10.15.4.11 Components Mismatch 

The compatibility test is performed at a power cycle. The compatibility test verifies the microcode version of the 
electronics. When the Drive detects the microcode version mismatch, the most likely cause is the result of incorrect 
parts used during a service action. 

If the error reported is Key/code/qualifier 4/40/80, Diagnostic failure, bring-up fail, the initiator should do the following: 

1. Retry Power cycle 

2. Check the send diagnostic end status. If the status is 

- GOOD, Return to normal processing 

- Check Condition Status, issue a Request Sense (03) and follow the recommendations for the sense data 
returned unless the sense data is for a component mismatch. If the sense data is for component mismatch, 
service the drive using the service guideline recommended in Section 10.15.1 "Drive Service Strategy". 
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10.15.4.12 Self Initiated Reset 

The Drive will initiate a self reset when the condition of the Drive cannot be determined. The internal reset will 
terminate any outstanding commands, release any reserved initiators, and stop the spindle motor. The initiator can 
recover by 

1. Logging the error 

2. Retrying the failing command. If the failing command completes with: 

- Good Status, return to normal processing 

- Self initiated reset sense, service the drive according the guidelines recommended in Section 10.15.1 "Drive 
Service Strategy". 

- Other, follow the recommendations for the error reported. 

10.15.4.13 Defect List Recovery 

This is not an error condition. 

The initiator either requested a defect list in a format (block or vendor specific) that the Drive does not support or the 
requested defect list(s) exceed the maximum list length that can be returned. If the Sense Key/Code/Qualifier are: 

1/1F/00, the requested list(s) exceed the maximum length that can be supported. The initiator should request one list 
at a time. If a single list exceeds the maximum returnable length, this may be an indication of a marginally operational 
drive. Service the drive following the service guidelines in Section 10.15.1 "Drive Service Strategy". 

1/1 C/01 or 1/1 C/02, the requested defect list is not in the format that the Drive supports. The requested defect list is 
returned in the physical (cylinder, sector, head) format. This is the default format. There is no initiator action required 
for this condition. 

10.15.4.14 Miscompare Recovery 

A Miscompare can occur on a Verify (2F) command or a Write and Verify (2E) with the byte check (BytChk) bit active. 
Recovery for a Miscompare error is different for the two commands. 

Verify Command 

The initiator should do the following: 

1. Verify that the data sent to the drive is the correct data for the byte-by-byte compare. 

2. Read the data from the media with a Read (08) or Read (28) command and verify that the data from the media 
is the expected data for the byte-by-byte compare. 

- If all data are correct, this is an indication that the data may have been read from the media incorrectly without 
an error detected. Service the drive using the procedure specified in Section 10.15.1 "Drive Service Strategy". 

- If all data are not correct, this is an indication that the data on the media is not the data the initiator expected. 
Rewrite the correct data to the media. 

Write and Verify Command 

The drive uses the same data in the data buffer to write then read and compare. A Miscompare error on the Write 
and Verify (2E) command is an indication that the drive cannot reliably write or read the media. Service the drive 
using the procedures specified in Section 10.15.1 "Drive Service Strategy". 


HGST Hard Disk Drive OEM Specification 
278 



10.15.4.15 Microcode Error 

The microcode from the interface is validated before the device operates using that microcode. When the validation 
detects incorrect or incomplete data, the Drive enters degraded mode. 

If the initiator attempted to load microcode using the Write Buffer (3B) retry the Write Buffer (3B). If the command 
completes with 

• Good Status - return to normal processing 

• Check Condition Status - service the drive using the service guidelines recommended in Section 10.15.1 "Drive 
Service Strategy". 

If the check sum error occurred during normal processing, the initiator may attempt to load microcode before deciding 
to service the drive using the service guidelines recommended in Section 10.15.1 "Drive Service Strategy". 

To load new microcode, the initiator should issue a Write Buffer (3B) command with the download and save option. 
If the Write Buffer (3B) command completes with 

• Good Status, return to normal processing. Retry the failing command. If the task complete with 

- Good Status - Continue normal processing. 

- Check Condition Status for check sum error - Service the drive using the service guidelines recommended in 
Section 10.15.1 "Drive Service Strategy". 

- Check Condition Status for any other error - follow the recommended recovery procedure for the error 
reported. 

• Check Condition Status for Check sum error, service the drive using the service guidelines recommended in 
Section 10.15.1 "Drive Service Strategy". 

• Check Condition Status for any other error, follow the recommendations for the returned sense data. 

10.15.4.16 Predictive Failure Analysis 

The Drive performs error log analysis and will alert the initiator of a potential failure. The initiator should determine if 
this device is the only device with error activity. 

If this drive is the only drive attached to the initiator with error activity, service the drive using the procedures specified 
in Section 10.15.1 "Drive Service Strategy". 

Note: Service for this drive can be deferred. The longer service is deferred, the more probable a failure can occur 
that will require immediate service. 

If more than this drive is experiencing error activity, the drive is probably not at fault. Locate and service the outside 
source causing error activity on this drive. 
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10.16 Commands for initialize the Write pointer 

The following commands will be initialize the Write Pointer:- 

1. Reset Write Pointer 

2. Format Unit command (Full format and Fast format included) 
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11 Firmware Security 

This chapter provides information on HGST encryption-specific HDD firmware and features. It is assumed that the 
reader is familiar with the referenced specifications and industry standards. 


11.1 Referenced Specifications and Standards 

11.1.1 TCG Specifications 

This section references 3 separate TCG specifications, which are available on the TCG website: 

( httpV/www. trustedcomputinggroup.org/ ): 

A) TCG Core Specification, Version 1.0, Revision 0.9 

- The TCG Core Specification is the general specification for trusted computing that encompasses all classes 
of devices, including storage 

B) TCG Storage Interface Interactions Specification (SIIF), Version 1.0, 1/27/2009 

- Specifies the interaction between the HDD and the SCSI/ATA protocols 

C) TCG Storage Security Subsystem Class (SSC): Enterprise, Version 1.0, rev 1.0, spec dated 1/27/09 

- A Security Subsystem Class defines minimum acceptable Core Specification capabilities of a storage 
device in a specific class (in our case - enterprise). 

- Storage devices in specific classes may have a subset of the capabilities that are defined in the core 
specification 

11.1.2 National Institute of Standards (NIST) 

This section references the following NIST publications, available on the NIST website 
( http://www.nist.gov/index.html ) 

• [SP800-38E] Recommendation for Block Cipher Modes of Operation: The XTS-AES Mode for Confidentiality 
on Storage Devices, SP800-38E, NIST, 2010 January 

• [SP800-38F] Recommendation for Block Cipher Modes of Operation: Methods for Key Wrapping, NIST, 2012 
December 

• [SP800-57] Recommendation for Key Management - Part I General (Revision 3), NIST, 2012 July 

• [SP800-90A] Recommendation for Random Number Generation Using Deterministic Random Bit Generators, 
NIST, 2012 Jan 

• [SP800-131A] Transitions: Recommendation for Transitioning the Use of Cryptographic Algorithms and Key 
Lengths, NIST, 2011 Jan 

• [SP800-132] Recommendation for Password-Based Key Derivation, NIST, 2010 December 
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11.1.3 Department of Defense 

DoD 5220.22-M, "National Industrial Security Program Operating Manual", 2/28/2006 

httpV/www. dtic.mil/whs/directives/corres/pdf/522022m.pdf 

DoD 5220.22-M Supplement 1, “National Industrial Security Program Operating Manual Supplement”, 02/1995 - 

http://www.dtic.mil/whs/directives/corres/pdf/522022MSupl.pdf 

11.1.4 RSA Laboratories Standards 

RSA-PSS - httpV/www.rsa.com/rsalabs/node.asp?id=2146 

RSA PKCS #5 v2.0 Password-Based Cryptography Standard - ftp://ftp.rsasecuritv.com/pub/pkcs/pkcs- 
5v2/pkcs5v2-Q.doc 

11.1.5 Other Standards 

T1 0 SCSI Standard (T1 0 homepage - http://www.tl0.org/index.htm11 
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11.2 Implementation Exceptions 

The following is a list that describes non-compliance with the TCG Enterprise SSC specification: 

• The SSC specification requires support for 1024 bands, but the implementation supports up to 64 bands. 

• The K_AES_256 table was implemented with only the UID and MODE columns. 

At any given time, the implementation allows for only 1 active session. In the case when a session is active and a 

new session is requested, the drive answers the host with SP_BUSY, instead of NO_SESSIONS_AVAILABLE 

11.3 Implementation Features and Details Outside of TCG 
Specifications 

The following features are outside of the TCG specifications. 

1. Ports 

2. Firmware signing 

The following implementation details are outside of the TCG SSC specification. 

a. The SSC States “The TPer SHALL implement the ParamCheck Longitudinal Redundancy Check (LRC) for Get 
and Set method calls on a PIN value". If the LRC check is erroneously applied to a value other than a PIN 
we ignore it, therefore no error is generated. 

b. When handling a "TCG cmd followed by a R/W cmd", all reads and writes that follow a TCG command will be 
processed in the normal way. No special handling or error messages will be sent to the host. It is up to the 
host to understand the possible outcomes of TCG commands and r/w command ordering and plan accordingly. 

c. CRC checking is disabled in all cases, so the drive will return data to the host. If the user successfully 
authenticates, then unencrypted data is returned to the host. If the user is unable to authenticate, encrypted 
data is returned to the host. 

d. The TPer replies with SP_BUSY for requests beyond 1 session. 
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11.4 Encryption Algorithms 

11.4.1 Advanced Encryption Standard (AES) Support 

AES encryption is implemented in hardware, with support for ECB or XTS mode for 128 bit or 256 bit keys. A single 
key is active at any one time within the AES hardware engine. Firmware is responsible for reading the keys from 
the hardware and also for determining which key is attached to a given LBA range; the hardware can only detect if 
the LBA has been encrypted or not. The TCG protocol does not allow for a user to choose or switch between AES 
algorithms, so it is up to the vendor to choose which AES algorithm is used in their implementation. The HGST TCG 
SSC implementation in firmware supports AES 256-XTS only. 

11.4.2 Level 0 Discovery Vendor Specific Data 

This section refers to section 10.2.14 of the TCG Storage Security Subsystem Class document (see the Specifications 
section of this document). This Vendor Specific section is documented below. 

Table 294 Persistent Reserve In (5E) 


Byte 

Bit 

7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 

16 

Version (set to 0) 

17 

Vendor Specific State Information 

18 

Reserved 

19 

RSVD MB_s 0 0 Diag_s Dload_s Locking_s FDE_s 

20 

Reserved 

21 

RSVD MB_e 0 0 Diag_s Dload_e Locking_e FDE_e 

22-47 

Reserved 


FDE_s/FDE_e - Full disk encryption is Supported (equivalent to Media Encryption in Locking Feature Descriptor 
Enterprise SSC 10.2.14) / Full disk encryption is Enabled on one or more band. 

Locking_s/Locking_e - LBA band locking is supported - locking object exists in the locking SP of the device (equivalent 
to Locking Enabled in Locking Feature Descriptor Enterprise SSC 10.2.14) / The locking object for a band has either 
ReadLocked or WriteLocked attribute set (equivalent to Locked in Locking Feature Descriptor Enterprise SSC 
10.2.14). 

Dload_s/Dload_e - support for Admin SP Firmware download port / Firmware download port via Admin SP is locked. 
Diag_s/Diag_e - Support for Admin SP vendor specific Diagnostic port / Diagnostics port via Admin SP is locked. 
MB_s/MB_e - Multiple encrypting bands supported / multiple encrypting bands enabled. This bit shall be set to 1 if 
more than one band exists in addition to the global band and is defined with at least one LBA. 

11.4.2.1 T10 End-To-End Data Protection 

AES encryption is performed after T10 end-to-end data protection data has been added, so that the T10 information 
is encrypted along with the customer data. 
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11.4.3 Pseudo Random Number Generation (PRNG) 

Pseudo-random number generation is implemented using the NIST SP800-90 PRNG. This PRNG uses AES as a 
primitive both for entropy mixing and entropy output. The successive values of the state of the PRNG are kept private 
to the device to ensure that keys generated by the device are unpredictable. The PRNG seed is derived from head 
position noise and has been measured to be uniformly distributed. 

11.4.4 Key Wrapping 

The NIST AES Key Wrapping Algorithm is used to encrypt a key with another key (KEK= Key Encryption Key). For 
any band i, the KEK_i is derived from PIN_i and saltj using the PBKDF2(Password-Based Key Derivation Function) 
algorithm. Then, the KEK_i is used to wrap the media encryption key using the NIST key wrapping algorithm. 

11.4.5 Key Erasure 

Cryptographic erase procedure 

• Erase and overwrite wrapped key material with 0x00. 

• Erase and store the new wrapped key material. 
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11.5 TCGSSC Tables 


Two copies of all TCG SCC tables and data structures are stored in the RID; one is used as a primary copy and the 
other as a backup copy. The backup copy is used in the event the primary copy becomes corrupted. Each time a 
write is executed to any TCG table, both the primary and backup copies of the tables are updated and saved in the 
RID. In the case of a corrupted copy, the good copy is always used to restore the corrupted copy to the correct 
state. If both copies of the tables become corrupted during operation, the tables will be reinitialized to default values 
automatically, and this will result in a key mismatch error when a read is attempted. 

The default values in the TCG tables created at the time of manufacturing are per the TCG SSC specification. The 
following tables contain VU (Vendor Unique) entries, which are set at the time of manufacturing. 

• Admin SP C_PIN table 

• Locking C_PIN table 

• K_AES_256 table 

• Locking SP Locking Access Control table 

• Locking Info Table 

• Locking SP Locking Table 

The VU entries for these tables are specified below. In addition, explanation of default values is given for non-VU 
entries that require it. 

11.5.1 Admin SP C_PIN Table and Locking SP C_PIN Table 

Per TCG SSC specification, the PIN is set to the MSID at manufacturing time. HGST has specified the MSID to be 
the serial number of the drive concatenated 4x. Try Limit is set to 0, meaning that there is no limit. Tries is set 0, 
meaning that there have been no fail attempts. Persistence is set to 0, meaning the “Tries” value does not persist 
through power cycles (The “Tries” value is reset to 0 after successful attempt or a power cycle). 

Table 295 HGST Implementation of Admin SP_CPIN & Locking C_PIN 


PIN 

Try Limit 

Tries 

Persistence 

SID 

0 

0 

0 

MSID 

0 

0 

0 





PSID 

0 

0 

0 


11.5.2 K_AES_256 Table 

The K_AES_256 table has 64 rows, one row for each band that can be allocated by the user. The first row is for the 
“global range”, also known as Band 0. This table was implemented without the “Name”, “Common Name”, and “Key” 
Columns. 

Table 296 HGST Implementation of K_AES_256 Table 


UID (8 byte hex) 

MODE 

00 00 08 06 00 00 00 01 

23 

00 00 08 06 00 00 00 02 

23 



00 00 08 06 00 00 00 40 

23 


The mode is specified in the TCG Enterprise SSC as a “Vendor Unique” (VU) entry. HGST initializes it in 
manufacturing to mode=23 (media encryption mode, per TCG specification) for all 64 entries. 
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11.5.3 Locking SP Access Control Table 

The TCG Enterprise SSC defines the values for Row Number and UID as “Vendor Unique” (VU). HGST has defined 
them to be the row number in the table, with a range of 0-459 The range is calculated using the following formula: 
number_of_rows = (#Supported Bands * 7) +12, where 

• #Supported Bands = 64 (The implementation supports 64 bands) 

• The number 7 comes from the fact that each band has 7 UID/method combinations 

• The number 12 comes from the following 12 methods that must be included in the table. 

1. This Sp/Authenticate 

2. Authority Table/Next 

3. Anybody Authority Object/ Get 

4. Band Masters Authority Object/ Get 

5. Erase Master Auth. Object / Get 

6. C_PIN table/Next 

7. Erase Master C_PIN Object/ Set 

8. Locking Info Table / Get 

9. Locking Table / Next 

10. DataStore / Get 

11. DataStore / Set 

12. ThisSP/Random 

Table 297 HGST Implementation of Locking SP Access Control Table 


Row Number 

UID 


0 

0 


1 

1 





459 

459 



11.5.4 Locking Info Table 

As specified in the TCG Enterprise SSC, this table has only 1 row. The “Vendor Unique” entries are specified in the 
table below. Encryption Support is initialized to Encryption Support=23 (media encryption mode) in manufacturing. 

Table 298 HGST Implementation of Locking Info Table 


NAME 

Version 

Encrypt 

Support 

Max Ranges 

Max ReEncryptions 

Keys Available Cfg 

0 

0 

23 

0 

0 

0 
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11.5.5 Locking SP Locking Table 


The “Vendor Unique” (VU) values for this table are shown below. 
Table 299 HGST Implementation of Locking SP Locking Table 


Next Key 

ReEncrypt 

State 

ReEncrypt 

Request 

Adv Key 
Mode 

Verf Mode 

Cont On 
Reset 

Last ReEncrypt 
LBA 

Last Re 
Enc Stat 

General 

Status 

00 00 00 00 

00 00 00 OOh 

0 

0 

0 

0 

0 

0 

0 

0 

00 00 00 00 

00 00 00 OOh 

0 

0 

0 

0 

0 

0 

0 

0 


In the ActiveKey column, the Enterprise SCC allows for byte 3 to be defined as either 05 or 06. The HGST 
implementation uses 06. 
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11.6 Firmware Download and Signing 

The HGST Firmware signing and download for encryption drives is meant to provide a mechanism for secure updates 
through the Host interface. Firmware is downloaded to the drive through the host interface, and the signature is 
verified using a public key installed in the reserved area during manufacturing, before it is loaded to RAM or installed 
in the reserved area on the HDD. 

Signature verification uses the RSA-PSS (Probabilistic Signature Scheme) signature verification algorithm with 
EMSA-SHA256 as padding function. 

All HGST firmware packages will be signed, but only encryption enabled drives will verify the signature. If the 
signature cannot be successfully verified on encryption drives, the firmware cannot be downloaded onto the HGST 
encryption drives. Failures to authenticate the firmware image will result in Check Condition with KCQ 5/26/9a (FRU 
0). The act of issuing a firmware download to the drive will result in an implicit close of all open sessions at the 
security layer. 


11.7 Ports 

The ports capability is an HGST feature which is not a requirement under TCG Enterprise SSC. In order to use the 
ports capabilities on encryption drives, the user must successfully authenticate. Once a user successfully 
authenticates, they may change the state of any of the ports at any time during an active session to either the locked 
or unlocked state. The functionality and definition of these ports is shown below in a table. 

The feature does make use of the TCG structures and tables. An additional table, the ports table, has been 
implemented, and additional entries were made to the Admin SP ACE table and the Admin SP AccessControl Table. 
The ports table and the modified TCG SSC tables are shown below. 


Table 300 Ports Functionality 


Port Name 

Description 

Firmware Download 

This port has 2 valid states: locked and unlocked. 

On encryption drives, the download port is unlocked initially, Lock On Reset is "Null". 
Code can be downloaded onto the drive after the signature is successfully verified. If the 
signature cannot be verified successfully, no firmware can be downloaded to the drive. 
The user can change the state of the firmware download port only after authentication. 

On non-encryption drives, this port will be set to unlocked at the factory, and the state 
cannot be changed by the user. Firmware will be downloaded to the non-encryption drive 
through this port without verification of the signature. 

Diagnostics 

This port has 2 valid states: locked and unlocked. This port allows HGST access to 
modify any TCG table or key. In order to open this port both the SID and the Maker 
authorities need to be authenticated. The purpose of this port is to aid HGST in debugging 


Table 301 Ports Table 


UID 

Name 

LocOnReset 

PortLocked 

00 01 00 02 00 01 00 02 

Firmware_Dload_Port 

Null 

FALSE 

00 01 00 02 00 01 00 01 

Diagnostic_Port 

PowerCycle 

TRUE 
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Table 302 Modified Admin SP ACE Table 


UID 

Name 

Cmn 

Name 

Boolean Expression 

Start 

End 

Column Start 

Column End 

00 00 00 08 00 00 00 01 

Anybody 

- 

00 00 00 09 00 00 00 01 

Null 

Null 



00 00 00 08 00 00 00 03 

Makers 


00 00 00 09 00 00 00 03 

Null 

Null 



00 00 00 08 00 00 02 01 

SID 


00 00 00 09 00 00 00 06 

Null 

Null 



00 00 00 08 00 00 8C 03 

SIDSetSelf 

- 

00 00 00 09 00 00 00 06 

Null 

Null 

“PIN” 

“PIN” 

00 00 00 08 00 00 8C 04 

MSIDGet 

- 

00 00 00 09 00 00 00 01 

Null 

Null 

“PIN” 

“PIN” 

00 00 00 08 00 00 8C 05 

SID Set Makers 

- 

00 00 00 09 00 00 00 06 

Null 

Null 

“Enabled” 

“Enabled” 

00 00 00 08 00 00 8C 06 

SID_Makers_ 

SetDiag 

SetDiag 

- 

00 00 00 09 00 00 00 06 
And 

00 00 00 09 00 00 00 03 

Null 

Null 

“PortLocked” 

“PortLocked” 

00 00 00 08 00 00 8C 07 

SID_Makers_ 

SetDiag 

SetDiag 

- 

00 00 00 09 00 00 00 06 
And 

00 00 00 09 00 00 00 03 

Null 

Null 

“PortLocked” 

“PortLocked” 

00 00 00 08 00 00 8C 08 

SID_GetPort 


00 00 00 09 00 00 00 06 

Null 

Null 

“PortLocked” 

“PortLocked” 

00 00 00 08 00 00 8C 09 

SID_GetPort 

- 

00 00 00 09 00 00 00 06 

Null 

Null 

“LockOnReset” 

“PortLocked” 


The last 2 lines of the table are the additional entries required to implement the firmware download port. 


Table 303 Modified Admin SP Access Control Table (part 1 of 2) 


Row 

Number 

UID 

Invoking ID 

Method ID 

Common Name 

ACL 

Log 

Add ACE 
ACL 

Remove 
ACE ACL 

Method ID 

VU 

VU 

00 00 00 00 
00 00 00 01 
(This SP) 

00 00 00 06 

00 00 00 OC 
(Authenticate) 

Anybody 
Authenticate 
Admin SP 

00 00 00 08 
00 00 00 01 
(Anybody) 

None 

Null 

Null 

00 00 00 06 
00 00 00 OC 
(Authenticate) 

VU 

VU 

00 00 00 09 
00 00 00 00 
(Authority 
table) 

00 00 00 06 00 
00 00 08 
(Next) 

Makers-Next- 
Authority table 

00 00 00 08 
00 00 00 03 
(Makers) 

None 

Null 

Null 

00 00 00 08 
00 00 00 03 
(Makers) 

VU 

VU 

00 00 00 09 
00 00 00 01 
(Anbody 
Authority 
object) 

00 00 00 06 

00 00 00 06 
(Get) 

Anyboby-Get- 
Anbody Authority 
Object 

00 00 00 08 
00 00 00 01 
(Anybody) 

None 

Null 

Null 

00 00 00 08 
00 00 00 01 
(Anybody) 

VU 

VU 

00 00 00 09 
00 00 00 03 
(Makers 
Authority 
object) 

00 00 00 06 

00 00 00 06 
(Get) 

Anyboby-Get- 
Anbody Authority 
Object 

00 00 00 08 
00 00 00 03 
(Makers) 

None 

Null 

Null 

00 00 00 08 
00 00 00 03 
(Makers) 

VU 

VU 

00 00 00 09 
00 00 00 06 
(SID Authority 
object) 

00 00 00 06 

00 00 00 06 
(Get) 

SID-Get-SID 
Authority Object 

00 00 00 08 
00 00 02 01 
(SID) 

None 

Null 

Null 

00 00 00 08 
00 00 02 01 
(SID) 
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Table 304 Modified Admin SP Access Control Table (part 2 of 2) 


Row 

Number 

UID 

Invoking ID 

Method ID 

Common Name 

ACL 

Log 

Add ACE 
ACL 

Remove 
ACE ACL 

Method ID 

VU 

VU 

00 00 00 0B 
00 00 00 00 
(C_PIN table) 

00 00 00 06 

00 00 00 08 
(Next) 

Makers-Next-C 
PIN table 

00 00 00 08 
00 00 00 02 
(Makers) 

None 

Null 

Null 

00 00 00 08 
00 00 00 02 
(Makers) 

VU 

VU 

00 00 00 0B 
00 00 00 01 
(SID CP IN 
object) 

00 00 00 06 

00 00 00 07 
(Set) 

SID Set Self-Set- 
Si D_C_ PIN object 

00 00 00 08 
00 00 8C 03 
(SID_SetSelf) 

None 

Null 

Null 

00 00 00 08 
00 00 02 01 
(SID) 

VU 

VU 

00 00 00 0B 
00 00 84 02 
(MSID CP IN 
object) 

00 00 00 06 

00 00 00 06 
(Get) 

MSID Get-Get- 
MSID CP IN 
object 

00 00 00 08 
00 00 8C 04 
(MSID_Get) 

None 

Null 

Null 

00 00 00 08 
00 00 02 01 
(SID) 

VU 

VU 

00 00 00 09 
00 00 00 03 
(Makers 
Authority 
object) 

00 00 00 06 

00 00 00 07 
(Set) 

SIDSetMakers- 
Set-Makers 
Authority Object 

00 00 00 08 
00 00 8C 05 
(SIDSetMak 
ers) 

None 

Nul 

Nul 

00 00 00 08 
00 00 02 01 
(SID) 

VU 

VU 

00 00 00 00 
00 00 00 01 
(ThisSP) 

00 00 00 06 

00 00 06 01 
(Random) 

Anybody-Random 

00 00 00 08 
00 00 00 01 
(Anybody) 

None 

Nul 

Nul 

00 00 00 08 
00 00 00 01 
(Anybody) 

VU 

VU 

00 01 00 02 
00 01 00 02 

00 00 00 06 

00 00 00 07 

SID_Set_Dload 

SIDSetPort 

None 

Nul 

Nul 

00 00 00 08 
00 00 02 01 
(SID) 

VU 

VU 

00 01 00 02 
00 01 00 02 

00 00 00 06 

00 00 00 06 

SID_GetDload 

SIDGetPort 

None 

Nul 

Nul 

00 00 00 08 
00 00 02 01 
(SID) 

VU 

VU 

00 01 00 02 
00 01 00 01 

00 00 00 06 

00 00 00 07 

SID_Makers_ 

SetDiag 

SID_Makers_ 

SetDiag 

None 

Nul 

Nul 

00 00 00 08 
00 00 02 01 
(SID) 

VU 

VU 

00 01 00 02 
00 01 00 02 

00 00 00 06 

00 00 00 06 

SID_Makers_ 

SetDiag 

SID_Makers_ 

SetDiag 

None 

Nul 

Nul 

00 00 00 08 
00 00 02 01 
(SID) 


The last 2 lines of the table are the additional entries required to implement the firmware download port. 
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11.8 MSID 

The MSID is set for each drive at the time of manufacturing to the serial number concatenated 4 times, to create a 
32 byte password. Thus, as an example, if the serial number of a drive is abcd1234, the MSID would then be set to 
abcd1234abcd1234abcd1234abcd1234. In TCG use cases such as “erase” or “repurpose”, this will be the MSID 
that is restored to the drive. 

HGST serial numbers are unique and are generated according to the following general rules: 

• Maximum length of the serial number is 8 characters 

• Serial numbers do not contain the characters “I" or "O". 


11.9 Logging 

HGST logging functions will not record any sensitive data such as customer plain text data, passwords, encryption 
keys or wrapping keys. 


11.10 Number of Sessions 

The HGST implementation supports 1 active session at a time. In the case when a session is active and a new 
session is requested, the drive answers the host with SP_BUSY. This covers the following 2 scenarios. 

• If an SP is in session and an attempt is made to start a second session with the same SP. 

• If an SP is in session and an attempt is made to start a second session with a different SP. 


11.11 Number of Bands 

The Enterprise SSC specification calls for support of up to 1024 bands. The HGST implementation supports a 
maximum of 64 bands. 


11.12 Number of COMIDs 

The HGST Enterprise SSC implementation supports 2 COMIDs, the minimum requirement in the Enterprise SSC 
specification. Only 1 comid can be in use at anytime. 
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11.13 Locked and Unlocked Behavior 

11.13.1 T10 SCSI commands 

The table below describes how basic T10 SCSI commands behave on encryption drives in the locked and unlocked 
states. 


Table 305 T10 SCSI Commands Behavior Table (part 1 of 2) 


Command 

Unloc 

ked 

Locked 

FORMAT UNIT (04) 

OEM 

Command can’t be executed when locked. Must 
unlock with MSID or password, before formatting. 

INQUIRY (12) 

OEM 

OEM 

LOG SELECT (4C) 

OEM 

OEM 

LOG SENSE (4D) 

OEM 

OEM-no access to customer data, will get some log 
information. 

MODE SELECT (15) 

OEM 

OEM 

MODE SELECT (55) 

OEM 

OEM 

MODE SENSE (1 A) 

OEM 

OEM 

MODE SENSE (5A) 

OEM 

OEM 

PERSISTENT RESERVE IN (5E) 

OEM 

OEM 

PERSISTENT RESERVE IN (5F) 

OEM 

OEM 

PRE-FETCH (34) 

OEM 

MSID only - limits DRAM accessibility. This is a read 
function. 

READ (6) - (08) 

OEM 

Ent_A authorized only 

READ (10) - (28) 

OEM 

Ent_A authorized only 

READ (12) - (A8) 

OEM 

Ent_A authorized only 

READ (16) - (88) 

OEM 

Ent_A authorized only 

READ (32) - (7F/09) 

OEM 

Ent_A authorized only 

READ BUFFER (3C) 

OEM 

OEM. Sensitive data cannot be snap shorted from 
DRAM. 

READ CAPACITY (10) - (25) 

OEM 

OEM 

READ CAPACITY (16) (9E/10) 

OEM 

OEM 

READ DEFECT DATA (37) 

OEM 

OEM 

READ DEFECT DATA (B7) 

OEM 

OEM 

READ LONG (3E) 

OEM 

Ent_A authorized only 

REASSIGN BLOCKS (07) 

OEM 

Command access denied if the effective range is locked. 

RECEIVE DIAGNOSTICS RESULTS (1C) 

OEM 

OEM 

RELEASE (17) 

OEM 

OEM 

RELEASE (57) 

OEM 

OEM 

REPORT DEVICE IDENTIFIER (A3/05) 

OEM 

OEM. 

REPORT LUNS (A0) 

OEM 

OEM. 

REPORT SUPPORTED OPERATION 
CODES (A3/0C) 

OEM 

OEM. 

REPORT SUPPORTED TASK 
MANAGEMENT FUNCTIONS (A3/0D) 

OEM 

OEM 

REQUEST SENSE (03) 

OEM 

OEM 

RESERVE (16) 

OEM 

OEM 

RESERVE (56) 

OEM 

OEM 

REZERO UNIT (01) 

OEM 

OEM 
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Table 306 T10 SCSI Commands Behavior Table (part 2 of 2) 


Command 

Unlocked 

Locked 


Command can’t be 
executed. (Command 
is executable when 

Command can’t be executed. (Command is executable 

SANITIZE(48) 

only BandO exists, 
locking of BandO is 
disabled and CPIN 
corresponds to MSID) 

when only BandO exists, locking of BandO is disabled 
and CPIN corresponds to MSID) 

SEEK (6) - (OB) 

OEM 

OEM 

SEEK (10) - (2B) 

OEM 

OEM 

SEND DIAGNOSTIC (ID) 

OEM 

Customer specific. 

SET DEVICE IDENTIFIER (A4/06) 

OEM 

OEM. 

START STOP UNIT (IB) 

OEM 

OEM 

SYNCHRONIZE CACHE (10) - (35) 

OEM 

OEM 

SYNCHRONIZE CACHE (16) - (91) 

OEM 

OEM 

TEST UNIT READY (00) 

OEM 

OEM 

VERIFY (2F) 

OEM 

Command access denied if the effective range is locked. 

VERIFY (12) - (AF) 

OEM 

Command access denied if the effective range is locked. 

VERIFY (16) - (8F) 

OEM 

Command access denied if the effective range is locked. 

VERIFY (32) - (7F/0A) 

OEM 

Command access denied if the effective range is locked. 

WRITE (6) - (0A) 

OEM 

Command access denied if the effective range is locked. 

WRITE (10) - (2A) 

OEM 

Command access denied if the effective range is locked. 

WRITE (12) - (AA) 

OEM 

Command access denied if the effective range is locked. 

WRITE (16) - (8A) 

OEM 

Command access denied if the effective range is locked. 

WRITE (32) - (7F/0B) 

OEM 

Command access denied if the effective range is locked. 

WRITE AND VERIFY (10) - (2E) 

OEM 

Command access denied if the effective range is locked. 

WRITE AND VERIFY (12) - (AE) 

OEM 

Command access denied if the effective range is locked. 

WRITE AND VERIFY (16) - (8E) 

OEM 

Command access denied if the effective range is locked. 

WRITE AND VERIFY (32) - (7F/0C) 

OEM 

Command access denied if the effective range is locked. 

WRITE BUFFER (3B) 

(HO) 

OEM (write DRAM 
on to drive) 

OEM 

WRITE BUFFER (3B) 

FW is signed and 

OEM. The write buffer command only functions to write 

(For FW download) 

downloaded 

to the buffer. 

WRITE LONG (3F) 

OEM 

Per TCG and T10 specification. Ent_A authorized only. 

WRITE SAME (41) 

OEM 

Ent_A authorized only 

WRITE SAME (16)-(93) 

OEM 

Ent_A authorized only 

WRITE SAME (32) - (7F/0D) 

OEM 

Ent_A authorized only 

SECURITYIN 

OEM 

Per TCG spec. Contains TCG payload. 

SECURITYOUT 

OEM 

Per TCG spec. Contains TCG payload. 

ZBC CLOSE ZONE(94h) 

Executable 

Executable 

ZBC FINISH ZONE(94h) 

Executable 

Executable 

ZBC OPEN ZONE(94h) 

Executable 

Executable 

ZBC REPORT ZONES(95h) 

Executable 

Executable 

ZBC RESET WRITE POINTER(94h) 

Executable 

Executable 
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11.13.2 TCG SSC Commands 

The table below describes how the required TCG Enterprise SSC commands behave on encryption drives in the 
locked and unlocked states. The TCG SSC requires the implementation of the Base, Admin, Locking, and Crypto 
Templates. As noted, the Crypto template was not implemented. In addition the SSC does not require any Admin 
Template tables or methods, so they are not mentioned in the table below. 


Table 307 TCG Enterprise SSC Commands Behavior -1 


Command 

Description 

unlocked 

Locked 

Session 

Management 

There are two types of sessions: 

1) Read-Only session. 

2) Read-Write session. 

The SSC requires us to support Read-Write sessions. Read-Only 
session is not allowed. A session is always initiated by the host. 
See the “Write” parameter in the Start Session method description 
@ TCG Core 5.2.3.1, and see SSC requirement in SSC 6.2.1.2. 



Properties 

Returns session properties to host. 

N/A 

N/A 

Start Session 

Start a session 

N/A 

N/A 

Syc Session 

Response to say session successfully started. 

N/A 

N/A 

Close Session 

End (Close) a session 

N/A 

N/A 


Table 308 TCG Enterprise SSC Commands Behavior -2 


Command 

Description 

unlocked 

Locked 

Discovery 

Allows the host to discover a TCG drive, its properties, and 
table values. 



Level 0 

Discovery request sent by host as IF-RCV command. 
Security Protocol = 0x01, COMID=0x0001 

N/A 

N/A 

Level 1 

Request basic TPER capabilities via properties using host 
messaging. 

Uses properties 
method. 

Uses properties 
method. 

Level 2 

TCG methods retrieve table cell values. 

See methods 
below. 

See methods 
below. 


Table 309 TCG Enterprise SSC Commands Behavior -3 


Command 

Description 

unlocked 

Locked 

Cryptographic 

Template 

Random function is only function 
required under SSC 



Random 

This is the only required method in the 
crypto template for SSC. It is a 
random number generator in software. 

N/A - Not related to 
bands/data on drive. 
Authentication required. 

N/A - Not related to 
bands/data on drive. 
Authentication required. 
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Table 310 TCG Enterprise SSC Commands Behavior -4 


Command 

Description 

unlocked 

Locked 

Base Template 

Mandatory 



Set 

Sets a value in a table 

N/A - table operations. 

Not related to 
bands/data on drive. 

N/A - table operations. 

Not related to 
bands/data on drive. 

Get 

Gets (reads) a value in a table 

N/A - table operations. 

Not related to 
bands/data on drive. 

N/A - table operations. 

Not related to 
bands/data on drive. 

ParamCheck 

LRC 

TPer implements param check LRC 
(longitudinal Redundancy Check) on get/set 
method calls on PIN value 

N/A 

N/A 

Next 

Iterates over all the rows of a table. 
Method requires user to specify "where" 
(row in table) and a "count". If where not 
specified, 1st row in table is used. For 
count not specified, default is number of last 
row in table. Returns 0 or more row 
number/uidref pairs currently in use in table, 
per parameters specified. 

N/A - table operations. 

Not related to 
bands/data on drive. 

N/A - table operations. 

Not related to 
bands/data on drive. 

Authenticate 

Authenticate an authority within a session 
(session must have successfully begun). 

Must be authorized. 

Must be authorized. 

GatACL 

Returns contents of access controls 
association's ACL stored in Method Table. 
The result is a list of uidrefs to ACE objects. 

N/A - table operations. 

Not to do with 
bands/data on drive. 

N/A - table operations. 

Not related to 
bands/data on drive. 


Table 311 TCG Enterprise SSC Commands Behavior -5 


Command 

Description 

unlocked 

Locked 

Locking Template 

Mandatory 



Erase 

Cryptographically erases user data in a specified LBA 
range and resets the access control (locking) of that 
LBA 

Can erase if 
authorized. 

Generates error. 
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11.14 Error Codes 

All error codes are compliant with the TCG Core specification and SIIF, except in the following case: 

• The maximum sessions allowed at any single time is 1. When a session is active and a new session is 
requested, the drive answers the host with SP_BUSY, instead of NO_SESSIONS_AVAILABLE. 


11.15 Customer Specific Requirements 

This specification does not cover customer-specific requirements. Customer-specific requirements are submitted 
by the customer to HGST in the form of a customer-specification document. 
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12 Zoned Block Commands (ZBC) 


12.1 Zone type models 

12.1.1 Zone type models introduction 


In a zone block device, each zone is one of the following types: 

a) a conventional zone (see 12.1.2); 

b) a sequential write required zone (see 12.1.3.3). 

12.1.2 Conventional zone model 

A conventional zone is a type of zone: 

a) that is not associated with a write pointer; and 

b) on which the drive does not return the errors described in 12.1.3.3 and performs operations as described in 


SBC-4. 


For conventional zones, the NON_SEQ bit must be set to zero in the REPORT ZONES command zone descriptor 
(see 13.4.2). 

12.1.3 Sequential write required zone models 
12.1.3.1 Sequential write required zones overview 

A sequential write required zone is a type of zone that has a write pointer that indicates a location within that zone. 
Each sequential write required zone has one write pointer. That write pointer indicates the LBAthat the application 
client should specify in the LOGICAL BLOCK ADDRESS field of a subsequent write command for that sequential 
write required zone. 

Figure 13 shows a sequential write required zone where no LBAs have been written since the last reset write pointer 
operation for that zone. The write pointer is set to the lowest LBA of that zone. 


lowest LBA lowest LBA+1 lowest LBA+2 ... highest LBA 


T write pointer 

Figure 13 Sequential write required zone and write pointer after reset write pointer operation with no subsequent writes 
Figure 14 shows a sequential write required zone where LBAs have been written since the last reset write pointer 
operation for that zone (i.e., LBAs less than the write pointer value) and LBAs have not been written since the last 
reset write pointer operation for that zone (i.e., LBAs greater than or equal to the write pointer value). 


lowest LBA ... highest LBA 



t write pointer 


Key: 



blocks that have been written 
blocks that have not been written 


Figure 14 Sequential write required zone and write pointer 
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Figure 15 shows the relationship of the write pointer for the following example: 

1) at time 1, the sequential write required zone starts with the write pointer set to the lowest LBA in that zone; 

2) at time 2, a write operation writes data starting at that zone’s lowest LBA and sets the write pointer to the last 
LBA written by the operation plus one; 

3) at time 3, a write operation: 

a) writes data that starts at the write pointer position after time 2 and extends to the end of that zone; and 

b) sets the ZONE CONDITION field in the REPORT ZONE command zone descriptor (see 13.4.2) to FULL 
(see 13.4.2) for that zone; and 

c) at time 4, a reset write pointer operation sets the write pointer to the lowest LBA of that sequential write 
required zone. 


Time 1 - Write pointer set to the lowest LBA of that zone 


lowest LBA 


highest LBA 

t write pointer 






Time 2-A write operation increases the write pointer 



lowest LBA 





highest LBA 




t write pointer 


Time 3- A write operation writes data to the end of that zone 


lowest LBA 





highest LBA 

Time 4- Reset write pointer operation sets the write pointer back to the lowest LBA of that zone 

lowest LBA 





highest LBA 


t write pointer 


Key: 


blocks that have been written 
blocks that have not been written 


Figure 15 Sequential write required zone example operations 

A reset write pointer operation sets the write pointer in a sequential write required zone to the lowest LBA of that 
sequential write required zone. A reset write pointer operation is requested by: 

a) RESET WRITE POINTER command (see 13.5); 

b) FORMAT UNIT command (see 8.4 and SBC-4); and 

c) SANITIZE command (see 12.4 and SBC-4). 

A reset write pointer operation results in setting the ZONE CONDITION field to EMPTY in the REPORT ZONES 
command zone descriptor (see 13.4.2) for that sequential write required zone. 
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12.1.3.2 Zone condition state machine 

12.1.3.2.1 Zone condition state machine overview 

The zone condition state machine (see Figure 16) controls the operation of each sequential write required zone. 
Read_Only state and Offline state which are defined in standard spec are not supported. The state machine consists 
of the following states: 

a) ZC1:Empty (see 12.1.3.2.2); 

b) ZC2:lmplicit_Open (see 12.1.3.2.3ZC2:lmplicit_Open state); 

c) ZC3:Explicit_Open (see 12.1.3.2.4); 

d) ZC4:Closed (see 12.1.3.2.5); and 

e) ZC5:Full (see 12.1.3.2.6); 

The drive maintain the zone state after processing a hard reset or a logical unit reset. 

The initial state for sequential write required zones (see 12.1.3.1) after power on is: 

a) the ZC1 :Empty state, if the write pointer is at the first LBA of the zone; 

b) the ZC4:Closed state, if the write pointer is greater than the first LBA of the zone, and the write pointer is 
less than or equal to the last LBA of the zone; and 

c) the ZC5:Full state, if the zone is full; 



Figure 16 Zone condition state machine 
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12.1.3.2.2 ZCTEmpty state 

12.1.3.2.2.1 ZCi:Empty state overview 

While in this state: 

a) the write pointer is pointing at the first LBA in the zone and the drive may not allocate open zone resources; 

b) if the drive processes a REPORT ZONES command, then the drive sets: 

A) the WRITE POINTER LBA field to a valid value; 

B) the ZONE CONDITION field to EMPTY; 

C) the RESET bit to zero; 

D) the NON SEQ bit to zero; and 

E) the remaining fields as described in 13.4.2, 

in the REPORT ZONES parameter data zone descriptor (see Table 319 ) for that zone; 

c) if a read command attempts to read any LBA in this zone, then the drive: 

A) terminates the read command with CHECK CONDITION status as described in 12.1.3.3.1; or 

B) returns the initialization pattern as described in 12.1.3.3.2; 
and 

d) if the drive processes a CLOSE ZONE command or a RESET WRITE POINTER command, then the drive 
does: 

A) not transition the zone from this state; and 

B) not consider this an error. 

12.1.3.2.2.2 Transition ZCl^Empty to ZC2Tmplicit_Open 

This transition occurs after successful completion of a zone management operation as the result of initiating the 
processing of a command that requests write operations. 

12.1.3.2.2.3 Transition ZCl-Empty to ZC3:Explicit_Open 

This transition occurs after successful completion of a zone management operation as the result of initiating the 
processing of a command that requests open zone operations. 
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12.1.3.2.3 ZC2Tmplicit_0pen state 

12.1.3.2.3.1 ZC2Tmplicit_0pen state overview 

While in this state: 

a) the drive allocates open zone resources: 

A) to maintain the accuracy of the write pointer; and 

B) for the availability of media to support write operations to this zone; 
and 

b) if the drive processes a REPORT ZONES command, then the drive sets: 

A) the WRITE POINTER LBA field to a valid value; 

B) the ZONE CONDITION field to IMPLICIT OPEN; and C) the remaining fields as described in 13.4.2, of the 
REPORT ZONES parameter data zone descriptor (see Table 319) for that zone. 

12.1.3.2.3.2 Transition ZC2Tmplicit_Open to ZCl-Empty 

This transition occurs after successful completion of a: 

a) reset write pointer operation; or 

b) close zone operation, if the write pointer is at the first LBA of the zone. 

12.1.3.2.3.3 Transition ZC2Tmplicit_Open to ZC3:Explicit_Open 

This transition occurs after successful completion of zone management operation as the result of initiating the 
processing of an OPEN ZONE command. 

12.1.3.2.3.4 Transition ZC2Tmplicit_Open to ZC4:Closed 

This transition occurs after successful completion of a close zone operation, if the write pointer is not at the first LBA 
of the zone. 

12.1.3.2.3.5 Transition ZC2Tmplicit_Open to ZC5-Full 

This transition occurs after: 

a) successful completion of a finish zone operation in this zone; or 

b) write operation that writes from the write pointer to the last LBA in the zone completes successfully. 
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12.1.3.2.4 ZC3^Explicit_0pen state 

12.1.3.2.4.1 ZC3:Explicit_Open state overview 

While in this state: 

a) the drive allocates open zone resources: 

A) to maintain the accuracy of the write pointer; and 

B) for the availability of media to support write operations to this zone; 

b) if the drive processes a REPORT ZONES command, then the drive sets: 

A) the WRITE POINTER LBA field to a valid value; 

B) the ZONE CONDITION field to EXPLICIT OPEN; and 

C) the remaining fields as described in 13.4.2, 

of the REPORT ZONES parameter data zone descriptor (see Table 319) for that zone; and 

c) if the drive processes an OPEN ZONE command: 

A) the drive does not transition the zone from this state; and 

B) this does not need to be considered an error. 

12.1.3.2.4.2 Transition ZC3:Explicit_Open to ZCl'Empty 

This transition occurs after successful completion of a: 

a) reset write pointer operation; or 

b) close zone operation, if the write pointer is at the first LBA of the zone. 

12.1.3.2.4.3 Transition ZC3:Explicit_Open to ZC4: Closed 

This transition occurs after successful completion of a close zone operation, if the write pointer is not at the first LBA 
of the zone. 

12.1.3.2.4.4 Transition ZC3-Explicit_Open to ZC5-Full 

This transition occurs after successful completion of a: 

a) finish zone operation; or 

b) write operation that writes from the write pointer to the last LBA in the zone. 
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12.1.3.2.5 ZC4^Closed state 

12.1.3.2.5.1 ZC4:Closed state overview 

While in this state: 

a) the drive makes open zone resources non-volatile: 

A) to maintain the accuracy of the write pointer; and 

B) for the availability of media to support write operations to this zone; 

b) if the drive processes a REPORT ZONES command, then the drive sets: 

A) the WRITE POINTER LBA field to a valid value; 

B) the ZONE CONDITION field to CLOSED; and 

C) the remaining fields as described in 13.4.2, 

of the REPORT ZONES parameter data zone descriptor (see Table 319 ) for that zone; and 

c) if the drive processes a CLOSE ZONE command, then the drive does: 

A) not transition the zone from this state; and 

B) not consider this an error. 

12.1.3.2.5.2 Transition ZC4^Closed to ZCl^Empty 

This transition occurs after successful completion of a reset write pointer operation. 

12.1.3.2.5.3 Transition ZC4^Closed to ZC2Tmplicit_Open 

This transition occurs after successful completion of a zone management operation as the result of initiating the 
processing of a: 

a) write command; or 

b) FINISH ZONE command. 

12.1.3.2.5.4 Transition ZC4:Closed to ZC3:Explicit_Open 

This transition occurs after successful completion of a zone management operation as the result of initiating the 
processing of an OPEN ZONE command. 
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12.1.3.2.6 ZC5^Full state 

12.1.3.2.6.1 ZC5:Full state overview 

While in this state: 

a) the drive is not maintaining a write pointer and as a result, the WRITE POINTER LBA field of the REPORT 
ZONES parameter data zone descriptor (see Table 319) is invalid. All LBAs in this zone are available to 
return user data; 

b) if the drive processes a REPORT ZONES command, then the drive sets: 

A) the ZONE CONDITION field to FULL; and 

B) the remaining fields as described in 13.4.2, 

of the REPORT ZONES parameter data zone descriptor for that zone; and 

c) if the drive processes a CLOSE ZONE command or a FINISH ZONE command, then the drive does: 

A) not transition the zone from this state; and 

B) not consider this an error. 

12.1.3.2.6.2 Transition ZC5:Full to ZCFEmpty 

This transition occurs after successful completion of a reset write pointer operation. 

12.1.3.3 Sequential write required zone model 
12.1.3.3.1 Sequential write required zone model overview 

A sequential write required zone is a sequential write required zone (see12.1.3.1) in which the drive requires that 
write commands specify a starting LBA that is equal to that zone’s write pointer. 

If the drive processes a write command without error, then the write pointer is modified to indicate the LBA where a 
subsequent write operation within the zone must be performed. 

If the ending LBA of a write command that completed without error is equal to the highest LBA of a host managed 
zone, then the ZONE CONDITION field in the REPORT ZONE command zone descriptor (see 13.4.2) is set to FULL 
and the write pointer is invalid. 

A reset write pointer operation (see 12.1.3.1) is the only method for causing an invalid write pointer to become valid. 
If the drive processes a write command that is terminated with CHECK CONDITION status, then the value of the 
write pointer may be unknown to the application client. 

The NONSEQ bit must be set to zero in the REPORT ZONES command zone descriptor (see 13.4.2). 

If the value in the MAXIMUM NUMBER OF OPEN SEQUENTIAL WRITE REQUIRED ZONES field is non-zero (see 
14.4.2) and the actual number of zones that are open is equal to the value in the MAXIMUM NUMBER OF OPEN 
SEQUENTIAL WRITE REQUIRED ZONES field, then a command that writes to a zone with the ZONE CONDITION 
field set to EMPTY must be terminated by the drive with CHECK CONDITION status with sense key set to ABORTED 
COMMAND and the additional sense code set to INSUFFICIENT ZONE RESOURCES. 

If the drive processes a read command with: 

a) the starting LBA in a sequential write required zone; 

b) the ending LBA in the same sequential write required zone; and 

c) the ending LBA is less than the write pointer, 

then the drive performs read operations for that command. 

If the drive processes a write command with: 

a) the starting LBA equal to the write pointer; 

b) the ending LBA in the same sequential write required zone; and 

c) an ending LBA that is equal to the last logical block within a physical block, 
then the drive performs write operations for that command. 

If the drive processes a write command with: 
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a) the starting LBA in a sequential write required zone that is not equal to the write pointer; or 

b) an ending LBA that is not equal to the last logical block within a physical block (see SBC-4), 

then the drive terminates the command with CHECK CONDITION status, with the sense key set to ILLEGAL 
REQUEST, and the additional sense code set to UNALIGNED WRITE COMMAND. 

If the drive processes a write command with an ending LBA that is not in the same sequential write required zone as 
the starting LBA, then the drive terminates the command with CHECK CONDITION status, with the sense key set to 
ILLEGAL REQUEST, and the additional sense code set to WRITE BOUNDARY VIOLATION. 

URSWRZ bit is set to one at manufacturing and it is not changable. If the drive processes a read command with: 

a) the starting LBA less than the write pointer and the ending LBA greater than or equal to the write pointer in the 
same zone; or 

b) the starting LBA greater than or equal to the write pointer and the ending LBA greater than or equal to the write 
pointer in the same zone, 

and the urswrz bit is set to: 

a) one, then the drive processes the command as described in 12.1.3.3.2; or 

b) zero, then the drive terminates the command with CHECK CONDITION status, with the sense key set to 
ILLEGAL REQUEST, and the additional sense code set to ATTEMPT TO READ INVALID DATA. 

If the drive processes a read command with the ending LBA in a different sequential write required zone than the 
starting LBA then the drive does: 

a) process the command as described in 12.1.3.3.2 without regard to sequential write required zone boundary, if 
the urswrz bit is set to one and all LBAs indicated by the command are in a sequential write required zone; 

b) terminate the command with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and 
the additional sense code set to READ BOUNDARY VIOLATION, if the URSWRZ bit is set to one and one or 
more LBAs indicated by the command are in a zone other than a sequential write required zone; and 

c) terminate the command with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and 
the additional sense code set to READ BOUNDARY VIOLATION, if the urswrz bit is set to zero. 

If the drive terminates a command with the additional sense code set to: 

a) UNALIGNED WRITE COMMAND; 

b) WRITE BOUNDARY VIOLATION; or 

c) ATTEMPT TO READ INVALID DATA, 

then the drive returns the write pointer associated with the sequential write required zone specified by the logical 
block address field of that command in the information field of the sense data (see SPC-5). 

If the drive processes a write command with the starting LBA that is not in a sequential write required zone and 
specifies an LBA that is in a sequential write required zone, then the drive terminates the command with CHECK 
CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to WRITE 
BOUNDARY VIOLATION. 

If the drive processes a read command with the starting LBA that is not in a sequential write required zone and 
specifies an LBA that is in a sequential write required zone, then the drive terminates the command with CHECK 
CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to ATTEMPT 
TO READ INVALID DATA. 

12.1.3.3.2 Processing unrestricted reads in sequential write required zones 

If the URSWRZ bit is set to one in the Zoned Block Device Characteristics VPD page (see 14.4.2), then a read 
operation on an LBA that has not been written or an LBA that has not been written since the last reset write pointer 
operation in that LBA’s sequential write required zone, returns user data set to the last initialization pattern that was 
set by the manufacturer. 
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12.2 Zoned block device extensions to block device model 

12.2.1 Zoned block device internal resource management 

A zoned block device requires internal resources to maintain each zone. Insufficient resources may result in 
degraded functionality (e.g., reduced performance, increased power consumption, or increased reporting of write 
errors). 

The drive uses the RESET bit in each zone descriptor (see 13.4.2) to report that an insufficient resources condition 
has been detected for the indicated zone. 

The application client clears the insufficient resources condition by sending a RESET WRITE POINTER command 
that specifies the affected zone to the drive. Before sending the RESET WRITE POINTER command, the application 
client may copy the logical block data in the affected zone to another location. 

12.2.2 Unexpected power removal 

If power is removed from a zoned block device prior to the drive completing the processing of a power loss expected 
event (see SAM-5) and: 

a) there are partially completed write operations; 

b) there is logical block data in volatile write cache; or 

c) write pointers for completed write operations are not saved to a nonvolatile location, 
then an unexpected power removal condition has occurred. 

An unexpected power removal condition may cause write pointers for partially completed write commands to be 
updated to reflect the partial logical block data written to the medium (e.g., the LBA plus one of the last logical block 
that the drive attempted to write). 

If after an unexpected power removal condition the application client requests the parameter data returned by a 
REPORT ZONES command (see 13.4), then the write pointers in the parameter data may not correspond to the 
ending LBA plus one of the last command to report completion in the sequential write required zone. 


12.3 Format operations 

All of the functions defined for the FORMAT UNIT command (see SBC-4) are available for zoned block devices. A 
FORMAT UNIT command affects all zones, however some characteristics are dependent on the zone type (see 
12.1) present in the zoned block device. A zoned block device may support multiple types of zones. 

For each conventional zone (see 12.1.2), a format operation is performed as specified in SBC-4. 

For each sequential write required zone (see 12.1.3), a format operation is performed as specified in SBC-4 and a 
reset write pointer operation (see 12.1.3.1) is performed 


12.4 Sanitize operations 

All of the functions defined for the SANITIZE command (see SBC-4) are available for zoned block devices. A 
SANITIZE command affects all zones, however some characteristics are dependent on the zone type (see 12.1) 
present in the zoned block device. A zoned block device may support multiple types of zones. 

For each conventional zone (see 12.1.2), a sanitize operation is performed as specified in SBC-4. 

For each sequential write required zone (see 12.1.3), a sanitize operation is performed as specified in SBC-4 with 
the following additional requirements: 

a) a successful sanitize operation shall include performing a reset write pointer operation (see 12.1.3.1); and 

b) a failed sanitize operation followed by a SANITIZE command with the service action of EXIT FAILURE 
MODE should result in the reset write pointer operations being successful. 
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12.5 Caches 

12.5.1 Caches overview 

Zoned block devices may implement caches. A cache is an area of temporary storage in the zoned block device 
(e.g., to enhance performance) separate from the medium that is not directly accessible by the application client. 

A cache stores logical block data. 

A cache may be volatile or non-volatile. A volatile cache does not retain data through power cycles. A non-volatile 
cache retains data through power cycles. There may be a limit on the amount of time a non-volatile cache is able 
to retain data without power (see 12.5.8). 

For cache model description in host aware devices see SBC-4. 

12.5.2 Read caching 

While processing read commands and verify commands, the drive may use the cache to store logical blocks that the 
application client may request at some future time. The algorithm used to manage the cache is not part of this 
standard. However, parameters are provided (see SBC-4) to advise the drive about future requests, or to restrict 
the use of cache for a particular request. 

12.5.3 Write caching 

While processing write commands, the drive may perform a write cache operation to store logical block data that is 
to be written to the medium at a later time with a write medium operation. This is called write-back caching. A write 
command may complete prior to logical blocks being written to the medium. As a result of using write-back caching 
there is a period of time during which the logical block data may be lost if: 

a) an unexpected power removal occurs (see 12.2.2); or 

b) a hardware failure occurs. 

There is also the possibility of an error occurring during the subsequent write medium operation. If an error occurs 
during the write medium operation, then the error may be reported as a deferred error on a later command. The 
application client may request that write-back caching be disabled with the Caching mode page (see SBC-4) to 
prevent detected write errors from being reported as deferred errors. Even with write-back caching disabled, 
undetected write errors may occur. Verify commands (e.g., VERIFY) may be used to detect those errors. 

If the drive reports a deferred error for a previous command due to a subsequent write medium operation in a 
sequential write required zone, then the drive may invalidate all the cached data in that zone following the LBA 
returned in the deferred write error. 

If processing a write command results in logical block data in cache that is different from the logical block data on the 
medium, then the drive shall retain that logical block data in cache until a write medium operation is performed using 
that logical block data. After the write medium operation is complete, the drive may retain that logical block data in 
cache. 
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12.5.4 Command interactions with caches 

The application client may affect behavior of the cache with: 

a) the SYNCHRONIZE CACHE commands (see SBC-4); and 

b) the Caching mode page (see SBC-4). 

When the cache becomes full of logical block data, the drive may replace the logical block data in the cache with new 
logical block data. The disable page out (DPO) bit in the CDBs of read commands, verify commands, and write 
commands allows the application client to influence the replacement of logical block data in the cache. A read 
command, verify command, or a write command with a DPO bit set to one is a hint to the drive that the logical blocks 
specified by that command are not likely to be accessed in the near future and should not be put in the cache or 
retained by the cache. 

Application clients may use the force unit access (FUA) bit in the CDBs of read commands or write commands to 
specify that the drive shall access the medium or non-volatile cache. If the FUA bit is set to one in a read command 
or a write command that specifies LBAs in a sequential write required zone, then all cached logical blocks in that 
zone shall be written to the medium or non-volatile cache. 

Setting the DPO bit to one (see SBC-4) and the FUA bit to one in all read commands and all write commands has the 
same effect as bypassing the volatile cache. 

12.5.5 Write operation and write medium operation interactions with 
caches 

For each LBA accessed by a write operation if a cache contains more recent logical block data for that LBAthan the 
medium, then the drive shall: 

a) perform a write cache operation to that LBA to update the logical block data in the cache; 

b) invalidate that LBA in the cache and perform a write medium operation to that LBA; or 

c) perform a write cache operation to that LBA to update the logical block data in the cache and perform a write 
medium operation to that LBA. 

For each LBA accessed by a write medium operation that is not part of a write operation if a cache contains more 
recent logical block data for that LBA than the medium, then the drive shall: 

a) perform a write cache operation to that LBA to update the logical block data in the cache; or 

b) invalidate that LBA in the cache, before the drive performs the write medium operation to that LBA. 

For any zone that has a write pointer where the write cache operation updated logical block data in the cache, that 
write pointer shall be updated to reflect the completed write operation. If an unexpected power removal occurs (see 
12.2.2), then that write pointer shall reflect the state of the medium and non-volatile cache, if any (e.g., the write 
pointer value may become lower as a result of data lost from volatile caches). 

12.5.6 Read operation and read medium operation interactions with caches 

For each LBA accessed by a read operation: 

1) if a cache contains more recent logical block data for that LBAthan the medium, then the drive shall perform a 
read cache operation from that LBA; or 

2) the drive shall perform a read medium operation from that LBA. 

For each LBA accessed by a read medium operation that is not part of a read operation: 

1) if a cache contains more recent logical block data for the LBAthan the medium, then the drive shall perform a 
write medium operation to that LBA; and 

2) the drive may invalidate that LBA in the cache, before the drive performs the read medium operation from that 
LBA. 
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12.5.7 Verify medium operation interactions with caches 

For each LBA accessed by a verify medium operation: 

1) if a cache contains more recent logical block data for the LBA than the medium, then the drive shall perform a 
write medium operation to that LBA; 

2) the drive may invalidate that LBA in the cache; and 

3) before the drive performs the verify medium operation from that LBA. 

12.5.8 Power loss effects on caches 

The power, if any, needed to maintain a non-volatile cache may decrease to the point that the drive is unable to ensure 
the non-volatility of the cache for a vendor specific interval of time (e.g., the battery voltage becomes too low to sustain 
cache contents beyond a vendor specific time). If this occurs and the Extended INQUIRY Data VPD page (see SPC- 
5) indicates that the drive contains non-volatile cache (i.e., NV_SUP bit set to one), then: 

a) if the reporting of informational exceptions control warnings is enabled (i.e., the EWASC bit is set to one in 
the Information Exceptions Control mode page (see SBC-4)), then the drive shall report the degraded non¬ 
volatile cache as specified in the Information Exceptions Control mode page with an additional sense code 
set to WARNING - DEGRADED POWER TO NON-VOLATILE CACHE; or 

b) if the reporting of informational exceptions control warnings is disabled (i.e., the EWASC bit is set to zero in the 
Information Exceptions Control mode page), then the drive shall establish a unit attention condition (see SAM- 
5) for the SCSI initiator port associated with every l_T nexus with the additional sense code set to WARNING - 
DEGRADED POWER TO NON-VOLATILE CACHE. 

Non-volatile caches may become volatile (e.g., battery voltage becomes too low to sustain cache contents when 
power is lost). If non-volatile caches become volatile, then logical block data transferred for read commands or write 
commands in which the force unit access (FUA) bit in the CDB is set to one may bypass the cache. 

If a non-volatile cache becomes volatile, then the drive shall set the REMAINING NON-VOLATILE TIME field to zero 
in the Non-volatile Cache log page (see SBC-4). 

If non-volatile cache becomes volatile and the Extended INQUIRY Data VPD page (see SPC-5) indicates that the 
drive contains non-volatile cache (i.e., the NV_SUP bit is set to one), then: 

a) if the reporting of informational exceptions control warnings is enabled (i.e., the EWASC bit is set to one in the 
Information Exceptions Control mode page (see SBC-4)), then the drive shall report the change in the cache 
as specified in the Information Exceptions Control mode page with the additional sense code set to 
WARNING - NON-VOLATILE CACHE NOW VOLATILE; or 

b) if the reporting of informational exceptions control warnings is disabled (i.e., the EWASC bit is set to zero in 
the Information Exceptions Control mode page), then the drive shall establish a unit attention condition (see 
SAM-5) for the SCSI initiator port associated with every l_T nexus with the additional sense code set to 
WARNING - NON-VOLATILE CACHE NOW VOLATILE. 

If: 

a) a power on or hard reset occurs; 

b) the Extended INQUIRY Data VPD page indicates that the drive contains a non-volatile cache (i.e., the 
NV SUP bit is set to one); and 

c) the non-volatile cache is currently volatile, then the drive shall establish a unit attention condition for the SCSI 
initiator port associated with every l_T nexus with the additional sense code set to WARNING - NON¬ 
VOLATILE CACHE NOW VOLATILE. 

12.5.9 Close zone and finish zone operation interactions with cache 

If the drive processes a close zone operation or a finish zone operation, then all cached logical blocks in that zone 
shall be written to the medium or non-volatile cache. 
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12.6 Zone management operation 

12.6.1 Zone management operation overview 

The zone management operation determines if a zone should be closed (see 12.6.2) in order to open another zone. 
If the zone management operation selects a zone to be closed, then a close zone operation is performed on the 
selected zone. 

If: 

a) the zone management operation determines that no zone is selected to be closed; or b) a zone 
is successfully closed, 

then the zone management operation is successful. 

12.6.2 Select a sequential write required zone 

If the following formula evaluates to true, then the zone management operation should not select a zone to be closed: 

z > (x + y) 
where: 

x is the number of open sequential write required zones with the zone condition of EXPLICIT OPEN; 
y is the number of sequential write required zones with the zone condition of IMPLICIT OPEN; and 
z is the contents of the MAXIMUM NUMBER OF OPEN SEQUENTIAL WRITE REQUIRED ZONES field of 
the Zoned Block Device Characteristics VPD page (see 14.4.2). 

If the following formula evaluates to true, then the drive terminates the command that initiated the zone management 
operation with CHECK CONDITION status, with sense key set to ABORTED COMMAND and the additional sense 
code set to INSUFFICIENT ZONE RESOURCES: 
x> z 

where: 

x is the number of open sequential write required zones with the zone condition of EXPLICIT OPEN; 
z is the contents of the MAXIMUM NUMBER OF OPEN SEQUENTIAL WRITE REQUIRED ZONES field of the 
Zoned Block Device Characteristics VPD page (see 14.4.2 ). 

If the following formula evaluates to true, then the drive chooses a zone in the ZC2:lmplicit_Open state and perform 
a close zone operation on the selected state: 

(z < (x + y)) AND y( > 0) 

where: 

x is the number of open sequential write required zones with the zone condition of EXPLICIT OPEN; 
y is the number of sequential write required zones with the zone condition of IMPLICIT OPEN; and 
z is the contents of the MAXIMUM NUMBER OF OPEN SEQUENTIAL WRITE REQUIRED ZONES field of 
the Zoned Block Device Characteristics VPD page (see 14.4.2). 
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13 Commands for zoned block devices 


13.1 CLOSE ZONE command 


The CLOSE ZONE command (see Table 312) requests the drive perform close zone operations. 
Table 312 CLOSE ZONE command 


Byte 

Bit 

1 7 1 6 | 

5 1 4 1 3 1 2 1 1 


0 

OPERATION CODE (94h) 

1 

Reserved 

SERVICE ACTION (01 h) 


2-9 

(MSB) 

ZONE ID 

(LSB) 

10-13 

Reserved 

14 


Reserved 

1 ALL 1 

15 

CONTROL 


The OPERATION CODE field and SERVICE ACTION field are defined in SPC-5 and shall be set to the values shown 
in (see Table 312) for the CLOSE ZONE command. 

The ZONE ID field specifies the lowest LBA of the sequential write required zone on which the drive performs a close 
zone operation. 

If the ALL bit is set to zero and the ZONE ID field does not specify the lowest LBA of a sequential write required zone, 
then the drive terminates the command with CHECK CONDITION status, with the sense key set to ILLEGAL 
REQUEST and the additional sense code set to INVALID FIELD IN CDB. 

An ALL bit set to one specifies that the drive performs a close zone operation on all zones with a zone condition of 
EXPLICIT OPEN (see see Table 321) or IMPLICIT OPEN. If the ALL bit is set to one, then the drive ignores the ZONE 
ID field. 

The CONTROL BYTE is defined in SAM-5. 
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13.2 FINISH ZONE command 

The FINISH ZONE command (see Table 313) requests the drive perform finish zone operations. The drive 

may be required to perform zone management operations as a result of initiating the processing of this command. 
The finish zone operation causes the zone condition to be set to the ZONE FULL condition for the specified zone. 
The drive returns the initialization pattern for all unwritten LBAs in this zone in response to a read operation. The drive 
may write the initialization pattern to the media for unwritten LBAs. 


Table 313 FINISH ZONE command 


Byte 

Bit | 

1 7 1 6 ! 

5 1 4 1 3 1 2 1 1 


0 

OPERATION CODE (94h) 

1 

Reserved 

SERVICE ACTION (02h) 



(MSB) 



2-9 


ZONE ID 

(LSB) 

10-13 

Reserved 

14 


Reserved 

1 ALL 1 

15 

CONTROL 


The OPERATION CODE field and SERVICE ACTION field are defined in SPC-5 and shall be set to the values shown 
in Table 313 for the FINISH ZONE command. 

The ZONE ID field specifies the lowest LBA of the sequential write required zone on which the drive performs a finish 
zone operation. 

If the ALL bit is set to zero and the ZONE ID field does not specify the lowest LBA of a sequential write required zone 
(see 12.1.3), then the drive terminates the command with CHECK CONDITION status, with the sense key set to 
ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN CDB. 

An ALL bit set to one specifies that the drive performs a finish zone operation on all zones with a zone condition of 
EXPLICIT OPEN (see see Table 321), IMPLICIT OPEN, and CLOSED. If the ALL bit is set to one, then the drive 
ignores the ZONE ID field. 

The CONTROL BYTE is defined in SAM-5. 
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13.3 OPEN ZONE command 


The OPEN ZONE command (see Table 314) requests the drive perform open zone operations. If the drive 
successfully processes an open zone operation, then the zone condition is set to EXPLICIT OPEN for that zone. 

Table 314 OPEN ZONE command 


Byte 

Bit 

1_ 7 _1_ 6 _L 

5 | 4 | 3 | 2 | 1 


0 

OPERATION CODE (94h) 

1 

Reserved 

SERVICE ACTION (03h) 


2-9 

(MSB) 

ZONE ID 

(LSB) 

10-13 

Reserved 

14 


Reserved 

Reserved 

15 

CONTROL 


The OPERATION CODE field and SERVICE ACTION field are defined in SPC-5 and shall be set to the values shown 
in Table 314 for the OPEN ZONE command. 

The ZONE ID field specifies the lowest LBA of the sequential write required zone on which the drive performs an 
open zone operation. 

If the ALL bit is set to zero and: 

a) the ZONE ID field does not specify the lowest LBA of a sequential write required zone (see 12.1.3), then the 
drive terminates the command with CHECK CONDITION status, with the sense key set to 

ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN CDB; 

b) the ZONE ID field specifies the lowest LBA of a sequential write required zone (see 12.1.3) and the zone 
condition is set to FULL (see Table 321) in the REPORT ZONES parameter data zone descriptor (see 
13.4.2), then the drive terminates the command with CHECK CONDITION status, with the sense key set to 
DATA PROTECT and additional sense code set to ZONE IS READ ONLY. 

An ALL bit set to one specifies that the drive performs a zone management operation and then an open zone operation 
on all CLOSED zones (see Table 321). If the ALL bit is set to one, then the drive ignores the ZONE ID field. 

If the ALL bit is set to one and the number of zones with a zone condition of EXPLICIT OPEN plus the number of 
zones with a zone condition of CLOSED is greater than the maximum number of open sequential write required zones, 
then the drive terminates the command with CHECK CONDITION status, with sense key set to ABORTED 
COMMAND and the additional sense code set to INSUFFICIENT ZONE RESOURCES. 

The CONTROL BYTE is defined in SAM-5. 
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13.4 REPORT ZONES command 

13.4.1 REPORT ZONES command introduction 

The REPORT ZONES command (see Table 315) requests that the drive transfer parameter data describing the zone 
structure of the zoned block device. 

Table 315 REPORT ZONES command 


Byte 

Bit 

1 7 1 6 1 

5 1 4 1 3 1 2 1 1 1 

0 

0 

OPERATION CODE (95h) 

1 

Reserved 

SERVICE ACTION (OOh) 


2-9 

(MSB) 

ZONE START LBA 

(LSB) 

10-13 

(MSB) 

ALLOCATION LENGTH 

(LSB) 

14 

Reserved 

REPORTING OPTIONS 


15 

CONTROL 


The OPERATION CODE field and SERVICE ACTION field are defined in SPC-5 and shall be set to the values shown 
in Table 315 for the REPORT ZONES command. 

The ZONE START LBA field specifies the lowest LBA of the first zone to be reported. If the ZONE START LBA field 
does not specify the lowest LBA of a zone, then the drive uses the lowest LBA of the zone that contains the specified 
LBA to specify the first zone to be reported. If the ZONE START LBA field specifies an LBA that is greater than the 
value in the MAXIMUM LBA field in the report zones parameter data, then the drive terminates the command with 
CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to 
LOGICAL BLOCK OUT OF RANGE. 


The ALLOCATION LENGTH field is defined in SPC-5. 

The REPORTING OPTIONS field (see Table 316) specifies the information to be returned in the parameter data. 
Table 316 REPORT ZONES Reporting option Field 


Code 

Description 

OOh 

List all of the zones in the zoned block device. 

01 h 

List the empty zones (i.e., the zone condition for the zone is EMPTY (see Table 321)). 

02h 

List the implicitly open zones (i.e., the zone condition for the zone is IMPLICIT OPEN (see Table 
321)). 

03h 

List the explicitly open zones (i.e., the zone condition for the zone is EXPLICIT OPEN 
(see Table 321)). 

04h 

List the closed zones (i.e., the zone condition for the zone is CLOSED (see Table 321)). 

05h 

List the full zones (i.e., the zone condition for the zone is FULL (see Table 321)). 

06h to OFh 

Reserved 

lOh 

List the zones with the RESET bit is set to one (see Table 319). 

11 h 

List the zones with the NON_SEQ bit is set to one (see Table 319). 

12h to 3Eh 

Reserved 

3Fh 

List the zones that are not sequential write required zones (i.e., the zone condition for the zone is 
NOT WRITE POINTER (see Table 321)). 


The CONTROL byte is defined in SAM-5. 
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13.4.2 REPORT ZONES parameter data 


The REPORT ZONES parameter data is defined in Table 317. 
Table 317 REPORT ZONES parameter data 


Byte 

Bit 

7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 

0-3 

(MSB) 

ZONE LIST LENGTH (n-63) 

(LSB) 

4 

Reserved SAME 

5-7 

Reserved 

8-15 

(MSB) 

MAXIMUM LBA 

(LSB) 

16-63 

Reserved 

Zone descriptors list 

64-127 

Zone descriptor [first] 



(n-63) - n 

Zone descriptor [last] 


The ZONE LIST LENGTH field contains the length in bytes of the zone descriptors list. The zone list length must be 
the number of zones reported multiplied by 64. The content of the ZONE LIST LENGTH field is not altered based on 
the allocation length (see SPC-5). 

The SAME field is defined in Table 318. 


Table 318 1 

SAME field description 

Code 

Description 

Oh 

The zone type and zone length in each zone descriptor may be different. 

1h 

The zone type and zone length in each zone descriptor are equal to the zone type and zone length 
indicated in the first zone descriptor. 

2h 

The zone type in each zone descriptor is equal to the zone type indicated in the first zone descriptor. 
The zone length of each zone except the last zone is equal to the zone length of the first zone 
descriptor. The zone length of the last zone is different than the zone length of the first descriptor. 

3h 

The zone length in each zone descriptor is equal to the zone length indicated in the first zone 
descriptor. The zone types for each descriptor may be different. 

4h to Fh 

Reserved 


The MAXIMUM LBA field contains the LBA of the last logical block on the logical unit. 
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Each zone descriptor (see Table 319) contains the description of one zone. The zone descriptors shall be sorted in 
ascending order based on the lowest LBA of each zone. 


Table 319 Zone descriptor format 


Byte 

Bit 

7 6 5 4 

3 | 2 | 1 | 0 

0 

Reserved 

ZONE TYPE 

1 

ZONE CONDITION 

Reserved NONSEQ RESET 

2-7 

Reserved 

8-15 

(MSB) 

ZONE LENGTH 

(LSB) 

16-23 

(MSB) 

ZONE START LBA 

(LSB) 

24-31 

(MSB) 

WRITE POINTER LBA 

(LSB) 

32-63 

Reserved 


The ZONE TYPE filed indicates the type of zone as shown in Table 320 
Table 320 Zone descriptor ZONE TYPE 


Code 

Description 

Oh 

Reserved 

1h 

Conventional 

2h 

Sequential write required 

3h to Fh 

Reserved 


The ZONE CONDITION field indicates the condition of the zone as described in Table 321. 
Table 321 Zone descriptor ZONE CONDITION FIELD 


Code 

Name 

Applies to zone type 
(see Table 320) 

Description 

Conv 

WPZ 

Oh 

NOT WRITE 

POINTER 

Yes 

No 

This zone does not have a write pointer and the 

WRITE POINTER LBA field contents are invalid. This 
zone is available to perform read operations and write 
operations. 

1h 

EMPTY 

No 

Yes 

The zone is in the ZC1 :Empty state 

2h 

IMPLICIT OPEN 

No 

Yes 

The zone is in the ZC2:lmplicit_Open state 

3h 

EXPLICIT OPEN 

No 

Yes 

The zone is in the ZC3:Explicit_Open state 

4h 

CLOSED 

No 

Yes 

The zone is in the ZC4:Closed state 

5h to Ch 

Reserved 

Dh 

READ ONLY 

Yes 

Yes 

Reserved, not supported 

Eh 

FULL 

No 

Yes 

The zone is in the ZC5:Full state 

Fh 

OFFLINE 

Yes 

Yes 

Reserved, not supported 


Key: Conv=Conventional zone, WPZ=Sequential write required zone 
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A NON_SEQ (non-sequential) bit set to zero at Conventional and Sequential write required zone. 

This product support only Conventilnal and Sequential write required zone, a NON_SEQ bit is always zero. 

A RESET bit set to zero indicates that the drive has sufficient resources to maintain the zone described by this zone 
descriptor. A RESET bit set to one indicates that the application client should send a RESET WRITE POINTER 
command (see 13.5) that specifies the zone described by this zone descriptor. If the zone type is conventional or 
sequential write preferred (see Table 320), thenT279 the drive sets the RESET bit to zero. 

The ZONE LENGTH field indicates the number of logical blocks in this zone. 

The ZONE START LBA field indicates the lowest LBA in this zone. 

The WRITE POINTER LBA field indicates the starting LBA that the application client should specify in the next write 
command associated with this zone. The content of the WRITE POINTER LBA field is invalid if: 

b) the zone type is conventional (see Table 320); or 

c) the content of the ZONE CONDITION field (see Table 321) indicate that the WRITE POINTER LBA field is 
invalid. 

If the zone type is set to 1h (i.e., conventional), then the WRITE POINTER LBA field is ignored by the application 
client. 
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13.5 RESET WRITE POINTER command 

The RESET WRITE POINTER command (see Table 322) requests the drive to perform reset write pointer operations. 
After successful completion of a reset write pointer operation, the zone condition shall be set to EMPTY for the 
specified sequential write required zone(s). 

Table 322 RESET WRITE POINTER command 


Byte 

Bit 

1_ 7 _1_ 6 _L 

5 | 4 | 3 | 2 | 1 j 

°_ 

0 

OPERATION CODE (94h) 

1 

Reserved 

SERVICE ACTION (04h) 



(MSB) 



2-9 


ZONE ID 

(LSB) 

10-13 

Reserved 

14 


Reserved 

ALL 

15 

CONTROL 


The OPERATION CODE field and SERVICE ACTION field are defined in SPC-5 and shall be set to the values shown 
in Table 322 for the RESET WRITE POINTER command. 

The ZONE ID field specifies the lowest LBA, if any, of the sequential write required zone on which the drive performs 
a reset write pointer operation. 

If the ALL bit is set to zero and the ZONE ID field does not specify the lowest LBA of a sequential write required zone 
(see 12.1.3), then the drive terminates the command with CHECK CONDITION status, with the sense key set to 
ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN CDB. 

An ALL bit set to one specifies that the drive performs a reset write pointer operation on all zones with a condition of 
IMPLICIT OPEN (see Table 321), EXPLICIT OPEN, CLOSED or FULL. If the ALL bit is set to one, then the drive 
ignores the ZONE ID field. 

The CONTROL byte is defined in SAM-5. 
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14 Parameters for zoned block devices 


14.1 Diagnostic parameters 


The diagnostic pages and their corresponding page codes are defined in Table 323. 
Table 323 Diagnostic page codes 


Diagnostic page name 

Page code 

Reference 

Diagnostic pages assigned by SPC-5 

30h to 3Fh 

SPC-5 

Direct access device diagnostic pages 

40h to 7Fh 

SBC-4 

SCSI enclosure services diagnostic pages 

01 h to 2Fh 

SES-4 

Vendor specific diagnostic pages 

80h to FFh 



14.2 Log parameters 

The log pages and their corresponding page codes and subpage codes are defined inTable 324. See SPC-5 for a 
detailed description of logging operations. 

Table 324 Log page codes and subpage codes 


Log page name 

Page code 1 

Subpage code 1 

Reference 

Application Client 

OFh 

OOh 

SPC-5 

Background Scan Results 

15h 

OOh 

SBC-4 

Informational Exceptions 

2Fh 

OOh 

SPC-5 

Power Condition Transitions 

1 Ah 

OOh 

SPC-5 

Protocol-Specific Port 

18h 

OOh to FEh 

SPC-5 

Read Error Counters 

03h 

OOh 

SPC-5 

Self-Test Results 

lOh 

OOh 

SPC-5 

Start-Stop Cycle Counter 

OEh 

OOh 

SPC-5 

Supported Log Pages 

OOh 

OOh 

SPC-5 

Supported Log Pages and Subpages 

OOh 

FFh 

SPC-5 

Supported Subpages 

01 h to 3Fh 

FFh 

SPC-5 

Temperature 

ODh 

OOh 

SPC-5 

Verify Error Counters 

05h 

OOh 

SPC-5 

Write Error Counters 

02h 

OOh 

SPC-5 

Vendor specific 

30h to 3Eh 

OOh to FEh 

n/a 


1 All page code and subpage code combinations not shown in this table are reserved. 
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14.3 Mode parameters 

The mode pages and their corresponding page codes and subpage codes are defined in Table 325. See SBC-4 for 
mode parameter block descriptors used by Ultrastar Archive HalO. 

Table 325 Mode page codes and subpage codes 


Mode page name 

Page code 

Subpage code 

Reference 

Application Tag 

OAh 

02h 

SBC-4 

Background Control 

ICh 

01 h 

SBC-4 

Caching 

08h 

OOh 

SBC-4 

Control 

OAh 

OOh 

SPC-5 

Control Extension 

OAh 

01 h 

SPC-5 

Disconnect-Reconnect 

02h 

OOh 

SPC-5 

Informational Exceptions Control 

ICh 

OOh 

SBC-4 

Power Condition 

1 Ah 

OOh 

SPC-5 

Protocol-Specific Logical Unit 

18h 

OOh 

SPC-5 

Protocol-Specific Port 

19h 

OOh 

SPC-5 

Read-Write Error Recovery 

01 h 

OOh 

SBC-4 

Return all mode pages and subpages a 

3Fh 

FFh 

SPC-5 

Return all mode pages only 
(i.e., not including subpages) a 

3Fh 

OOh 

SPC-5 

Return all subpages for the specified 
mode page code a 

OOh to 3Eh 

FFh 

SPC-5 

Verify Error Recovery 

07h 

OOh 

SBC-4 

Vendor specific b 


Reserved 

all other combinations 


a Valid only for the MODE SENSE command. 

b These vendor specific mode page code and subpage code combinations do not require a page format: mode 
page OOh with subpage code OOh and mode page codes 20h to 3Eh with all subpage codes. 
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14.4 Vital product data (VPD) parameters 

14.4.1 VPD parameters overview 

The VPD pages and their corresponding page codes are defined in Table 326 and in SPC-5. 
Table 326 VPD page codes 


VPD page name 

Page code a 

Reference 

ATA Information 

89h 

SAT-3 

Block Device Characteristics 

Blh 

SBC-4 

Block Limits 

BOh 

SBC-4 

Zoned Block Device Characteristics 

B6h 

14.4.2 


a All page codes not shown in this table or SPC-5 are reserved. 


14.4.2 Zoned Block Device Characteristics VPD page 

The Zoned Block Device Characteristics VPD page (see Table 327) provides a list of parameters that are specific to 
zoned block devices. 

Table 327 Zoned Block Device Characteristics VPD page 


Byte 

Bit 

7 | 6 | 5 

4 | 3 | 2 | 1 | 0 

0 

PERIPHERAL QUALIFIER 

PERIPHERAL DEVICE TYPE 

1 

PAGE CODE (B6h) 

2-3 

PAGE LENGTH (003Ch) 

4 

Reserved URSWRZ 

5-15 

Reserved 

16-19 

(MSB) 

MAXIMUM NUMBER OF OPEN SEQUENTIAL WRITE REQUIRED ZONES 

(LSB) 

20-63 

Reserved 


The PERIPHERAL QUALIFIER field and PERIPHERAL DEVICE TYPE field are defined in SPC-5. 

The PAGE CODE field and PAGE LENGTH field are defined in SPC-5 and shall be set to the values shown in Table 
327 for the Zoned Block Device Characteristics VPD page. 

An unrestricted read in sequential write required zone (URSWRZ) bit set to zero indicates that the drive does not 
support reading unwritten logical blocks or reads across zone boundaries in sequential write required zones. A 
URSWRZ bit set to one indicates that the drive supports reading unwritten logical blocks and reads across zone 
boundaries in sequential write required zones. The details of processing reads in sequential write required zones 
are described in 12.1.3.3.2. 

The MAXIMUM NUMBER OF OPEN SEQUENTIAL WRITE REQUIRED ZONES field indicates the maximum number 
of sequential write required zones that are allowed to be open (see 12.1.3.3). A value of FFFF_FFFFh indicates 
that there is no limit for the number of open sequential write required zones. 
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15 SCSI Sense Data 


15.1 SCSI Sense Data Format Introduction 

Sense data is returned as CHECK CONDITION status and as parameter data in response to the REQUEST SENSE 
command. The sense data returned by the drive can be in either fixed or descriptor format 

15.1.1 Sense Data Format 

Format of sense data returned as a CHECK CONDITION STATUS is based on the value of the D SENSE bit in the 
Control mode page (See section 8.11.9 "Mode Page OA"). The REQUEST SENSE command may be used to 
request either the fixed format sense data or the descriptor format sense data (See section 8.37 "REQUEST SENSE"). 

15.1.2 Sense Data Length 

Length of the sense data returned as part of CHECK_CONDITION status is determined by the sense data format: 

a) Length of fixed format sense data is always 32 byte. 

b) Length of descriptor format sense data is 60 byte (Generic Configuration) 

For REQUEST SENSE command, length of the sense data is the number of bytes in the command’s Allocation 
Length or the sense data length described above, whichever is less. 

15.1.3 Sense Data Response Code 

The first byte of all sense data contains the RESPONSE CODE field that indicates the error type and format of the 

sense data. Table 328 “Sense data response codes.” shows the RESPONSE CODE values which may be returned 
by the drive 

Table 328 Sense data response codes 


Response Code 

Error Type 

Sense Data Format 

70h 

Current 

Fixed 

71 h 

Deferred 

Fixed 

72h 

Current 

Descriptor 

73h 

Deferred 

Descriptor 


Current Error: This indicates an error for the current command. 

Deferred Error: This indicates that the error is for a previous command that has already returned a good status. 

Such commands are associated with the immediate bit or write caching. Format unit (04h) command 
is an example of a command that may return a deferred error. 
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15.2 Fixed Format Sense Data 


Table 329 shows the format of fixed format of the sense data returned by the drive. 
Table 329 Fixed 


Byte 

Bit 

7 

6 | 5 | 4 | 3 | 2 | 1 | 0 

0 

Valid 

Response Code (70h or 71 h) 

1 

RSVD = 0 

2 

0 1 LI 0 Sense Key 

3-6 

(MSB) 

Information Bytes 

(LSB) 

7 

Additional Sense Length 

8-11 

(MSB) 

Command Specific Information 

(LSB) 

12 

Additional Sense Code 

13 

Additional Sense Code Qualifier 

14 

FRU = 0 

15 

SKSV Sense-Key Specific Bits 

16-17 

Sense-Key Specific Bytes 

18-19 

Reserved = 0 

20-23 

Vendor unique Error information 

24-29 

Command Specific Information 

30-31 

Reserved = 0 


15.2.1 Valid (Bit 7 of byte 0) 


Table 330 Valid 


0 

The Information Bytes (byte 3 through 6) are not defined. 

1 

The Information Bytes (byte 3 through 6) contain a valid logical block address. 


15.2.2 Response Code (Bit 6 - 0 of byte 0) 


Table 331 Response Code 


70h 

Current Error. See section 15.1.3 "Sense Data Response Code" for more details. 

71 h 

Deferred Error. See section 15.1.3 "Sense Data Response Code" for more details. 
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15.2.3 ILL Incorrect Length Indicator (Bit 5 of byte 2) 

The ILI bit is valid for the Read Long (3Eh) command and Write Long (3Fh) command only. ILI set to one and Valid 
Bit set to one indicates that the requested logical block length does not match the logical block length of the data on 
the medium for a Read Long or Write Long command. The Information field contains residue information about the 
error. ILI set to zero indicates there is no incorrect length condition. 

Table 332 ILI 

0 No Incorrect Length condition. 

1 Incorrect Length Indicated. 


Valid 

ILI 

Command = Read 
Long or Write Long 

Description 

X 

0 

X 

No incorrect length condition 

1 

1 

yes 

Requested Logical block Length does not match the logical block 
length of the data on the disk 


15.2.4 Sense Key (Bit 3 - 0 of byte 2) 

The sense key provides generic categories in which error and exception conditions can be reported. Initiators would 
typically use sense keys for high level error recovery procedures. 

Oh No Sense 

There is no sense key information to be reported for the logical unit. 

1h Recovered Error 

The last command completed successfully with some recovery action performed by the drive. More 
detailed information is available in the Additional Sense Code and Additional Sense Code Qualifier. 

2h Not Ready 

The logical unit addressed cannot be addressed. More detailed information is available in the Additional 
Sense Code and Additional Sense Code Qualifier. 

3h Medium Error 

The command terminated with an unrecoverable error condition caused by a flaw in the media or an 
error in the recorded data. More detailed information is contained in the Additional Sense Code and 
Additional Sense Code Qualifier. 

4h Hardware Error 

The drive detected an unrecoverable hardware error while performing a command or during a diagnostic 
test. More detailed information is contained in the Additional Sense Code and Additional Sense Code 
Qualifier. 

5h Illegal Request 

There was an illegal parameter in the command descriptor block or additional parameter supplied as 
data. If an invalid parameter is found in the CDB, then the command is terminated without altering the 
medium. If an invalid parameter is found in parameters supplied as data, then the drive might have 
altered the medium. 

6h Unit Attention 

Indicates that the drive entered in the 'Unit Attention Condition'. (See Section 10.1.5 "Unit Attention 
Condition") 

7h Data Protect 

8h Not used 

9h Vendor Specific 

Ah Not used 

Bh Aborted command 

The drive aborted the command. 

Ch-Dh Not Implemented 
Eh Miscompare 

Fh Reserved 
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15.2.5 Information Bytes (Byte 3 through 6) 

This field is only valid when VALID bit is one. 

• ILI = 0: This field contains the unsigned LBA associated with the sense key. The LBA reported will be within the 
LBA range of the command as defined in the CDB. 

Note: An LBA other than the command LBA may be reported on the Reassign Block (07h) command. 

Note: When the value that need to be stored in the Information field is greater than OxFFFFFFFF (e.g. an LBA 
greater than 2TiB) the VALID bit will always be set to 0. To retrieve such information in such cases, the 
drive must be configured to return sense data in descriptor format. See section 8.11.9 "Mode Page OA" for 
details 

• ILI = 1: This field contains the difference (residue) of the requested length in bytes. Negative values are indicated 
by two's complement notation. 


Table 333 Information Bytes (Byte 3 through 6) 


Valid 

ILI 

Description 

0 

X 

0x00000000 - (not used/invalid) 

1 

0 

LBA 

1 

1 

Residue of the requested length in bytes 


15.2.6 Additional Sense Length (Byte 7) 

Indicates the remaining number of bytes in the sense data. (It is always set to 18h.) 

15.2.7 Command Specific Information (Byte 8 through ll) 

This field is unused and will be set to zero. 
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15.2.8 Additional Sense Code/Qualifier (Byte 12 and 13) 


The following table shows the description of the combination of Sense Key / Sense Code / Qualifier. 


Valid Sense Key, Code, Qualifier Combinations Used by the Drive 

Key 

Code 

Qual 

Description 




Sense Key = No Sense 

00 

00 

00 

No Additional Sense Information 




0000 No Error 




Sense Key = No Sense 

0 

OB 

01 

SMART Temperature Warning 




1A02 SMART: Temperature Warning (No Sense) 




2A02 SMART: Temperature Warning (Recovered Sense) 




3A02 SMART: Temperature Warning (Unit Attention) 

0 

OB 

03 

SMART Background Self-Test Failure 




1A03 SMART: Background Self-Test Failure (No Sense) 




2A03 SMART: Background Self-Test Failure (Recovered Sense) 




3A03 SMART: Background Self-Test Failure (Unit Attention) 

0 

OB 

04 

SMART Background Pre-Scan Failure 




1A04 SMART: Background Pre-Scan Failure (No Sense) 




2A04 SMART: Background Pre-Scan Failure (Recovered Sense) 




3A04 SMART: Background Pre-Scan Failure (Unit Attention) 

0 

OB 

05 

Background Media Scan Failure Warning 




1A05 SMART: Background Media Scan Failure (No Sense) 




2A05 SMART: Background Media Scan Failure (Recovered Sense) 




3A05 SMART: Background Media Scan Failure (Unit Attention) 

0 

5D 

21 

Milli-Actuator Error 




1A21 SMART: Milli-Actuator Error (No Sense) 




2A21 SMART: Milli-Actuator Error (Recovered Sense) 




3A21 SMART: Milli-Actuator Error (Unit Attention) 

0 

5D 

22 

Extreme Over-Temperature Warning 




1A22 SMART: Extreme Over-Temperature Warning (No Sense) 




2A22 SMART: Extreme Over-Temperature Warning (Recovered Sense) 




3A22 SMART: Extreme Over-Temperature Warning (Unit Attention) 

0 

5D 

50 

Load/Unload cycle Count Warning 




1A50 SMART: Load/Unload Cycle Count Warning (No Sense) 




2A50 SMART: Load/Unload Cycle Count Warning (Recovered Sense) 




3A50 SMART: Load/Unload Cycle Count Warning (Unit Attention) 

0 

5D 

5B 

Spinup Retry Count Warning 




1A5B SMART: Spinup Retry Count Warning (No Sense) 




2A5B SMART: Spinup Retry Count Warning (Recovered Sense) 




3A5B SMART: Spinup Retry Count Warning (Unit Attention) 

0 

5D 

62 

Read/Write Error Rate Warning 




1A32 SMART: Read Error Rate Warning (No Sense) 




2A32 SMART: Read Error Rate Warning (Recovered Sense) 




3A32 SMART: Read Error Rate Warning (Unit Attention) 




1A4A SMART: Write Error Rate Warning (No Sense) 
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2A4A SMART: Write Error Rate Warning (Recovered Sense) 




3A4A SMART: Write Error Rate Warning (Unit Attention) 

0 

5D 

63 

Seek Error Rate Warning 




1A43 SMART: Seek Error Rate Warning (No Sense) 




2A43 SMART: Seek Error Rate Warning (Recovered Sense) 




3A43 SMART: Seek Error Rate Warning (Unit Attention) 

0 

5D 

64 

Spare Sector Availability Warning 




1A14 SMART: Spare Sector Availability Warning (No Sense) 




2A14 SMART: Spare Sector Availability Warning (Recovered Sense) 




3A14 SMART: Spare Sector Availability Warning (Unit Attention) 

0 

5D 

66 

Spinup Time Warning 




1A56 SMART: Spinup Time Warning (No Sense) 




2A56 SMART: Spinup Time Warning (Recovered Sense) 




3A56 SMART: Spinup Time Warning (Unit Attention) 

0 

5E 

01 

ldle_A Condition activated by timer 




1831 CMD: Power Mode ldle_A By Timer 

0 

5E 

02 

Standby_Z Condition activated by timer 




1834 CMD: Power Mode Standby_Z By Timer 

0 

5E 

03 

ldle_A Condition activated by Command 




1835 CMD: Power Mode ldle_A By Command 

0 

5E 

04 

Standby_Z Condition activated by Command 




1838 CMD: Power Mode Standby_Z By Command 

0 

5E 

05 

ldle_B Condition activated by timer 




1832 CMD: Power Mode ldle_B By Timer 

0 

5E 

06 

ldle_B Condition activated by Command 




1836 CMD: Power Mode ldle_B By Command 

0 

5E 

07 

ldle_C Condition activated by timer 




1833 CMD: Power Mode ldle_C By Timer 

0 

5E 

08 

ldle_C Condition activated by Command 




1837 CMD: Power Mode ldle_C By Command 

0 

5E 

09 

Standby_Y Condition activated by timer 




1839 CMD: Power Mode Standby_Y By Timer 

0 

5E 

0A 

Standby_Y Condition activated by Command 




183A CMD: Power Mode Standby_Y By Command 




Sense Key = Recovered Error 

1 

02 

00 

No Seek Complete 




141B Servo: Recovered Current error 




141D Servo: Recovered Seek timeout 




141F Servo: Recovered Seek error 




142B Servo: Recovered RRO Calibration timeout 

1 

03 

00 

Peripheral Device Write Fault 




1733 Media: Recovered Read Write Abort Error 




1737 Media: Recovered Post Write Abort Error 




1739 Media: Recovered Post PES Check Write Abort Error 




17E0 Media: Recovered Write Splice Error 




1ED6 Media: Recovered R/W Abort Off Track Write Error 
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1ED8 Media: Recovered R/W Abort RRO Field Misread Error 




1 EDA Media: Recovered R/W Abort RRO Field Missing Error 




1 EDO Media: Recovered R/W Abort Idle Seek Error 




1EDE Media: Recovered R/W Abort Seek Timeout Error 




1EE0 Media: Recovered R/W Abort Estimator Error 




1EE2 Media: Recovered R/W Abort Predictor Error 




1EE4 Media: Recovered R/W Abort PES Error 




1EE6 Media: Recovered R/W Abort Seek Start Error 




1EE8 Media: Recovered R/W Abort PES Reset Error 




1EEA Media: Recovered R/W Abort SID Unlock Error 




1 EEC Media: Recovered R/W Abort WCS Error 




1EEE Media: Recovered R/W Abort Hard Reset Error 




1EF0 Media: Recovered R/W Abort Shock Error 




1EF2 Media: Recovered R/W Abort Unlock Macro Error 




1EF4 Media: Recovered R/W Abort Sharp Error 




1EF6 Media: Recovered R/W Abort Aggressive Error 




1EF8 Media: Recovered R/W Abort SVGA Limit Error 




1EFA Media: Recovered R/W Abort Gray Code Error 




1EFC Media: Recovered R/W Abort Burst Error 




1EFE Media: Recovered R/W Abort No STM Error 

1 

09 

00 

Track Following Error 




1421 Servo: Recovered Track following error 




1423 Servo: Recovered Track follow timeout 

1 

OC 

01 

Recovered Write Error with Auto Reallocation - Auto Reallocated 




D703 Media: Auto Reallocated Write Error 

1 

OC 

03 

Recovered Write Error - Recommend Reassignment 




1704 Media: Recovered Write Error - Recommend reassign 

1 

10 

01 

Recovered Guard Check Error 




17BC Media: Recovered Guard Check Error 

1 

10 

02 

Recovered Application Tag Error 




17BA Media: Recovered Application Tag Error 

1 

10 

03 

Recovered Reference Tag Error 




17B8 Media: Recovered Reference Tag Error 

1 

11 

14 

Recovered LBA Write Correctable Error 




17CB Media: Recovered LBA Write Correctable Error 

1 

15 

00 

Random Positioning Error 




1714 Media: Recovered Sector Overflow Error 




173D Media: Recovered Sector Miss Error 




1770 Media: Recovered SID Timeout Error 




17B2 Media: Recovered Abort Window Error 




17EE Media: Recovered Sector Number Cylinder Error 

1 

16 

00 

Data Synchronization Mark Error 




1735 Channel: Recovered No Sync Detected Error 




173B Media: Recovered Data Address Mark Error 




17A9 Media: Recovered Read Overrun Error 

1 

16 

01 

Data Sync Error - Data Rewritten 
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E70E Media: Recovered Data Address Mark Error - Rewritten 

1 

16 

02 

Data Sync Error - Recommend Rewrite 




E70F Media: Recovered Data Address Mark Error - Recommend Rewrite 

1 

16 

03 

Data Sync Error - Auto Reallocated 




D710 Media: Recovered Data Address Mark Error - Reassigned 

1 

16 

04 

Data Sync Error - Recommend Reassignment 




E711 Media: Recovered Data Address Mark Error - Recommend Reassign 

1 

17 

01 

Recovered Data with Retries 




172C Media: Recovered Data 




172E Media: Recovered Error on Last Data Read 




176C Media: Recovered MEDC Correctable Error 




1782 Media: Recovered Force Soft Error 




1784 Media: Recovered Channel Sector Marginal Error 




17E6 Media: Recovered NRZ Sector Marginal Error 

1 

17 

06 

Recovered Data Without LDPC - Data Auto-Reallocated 




D705 Media: Error With OTF Correction - Reassigned 

1 

17 

07 

Recovered Data Without LDPC - Recommend Reassignment 




E706 Media: Error With OTF Correction - Recommend Reassign 

1 

17 

08 

Recovered Data Without LDPC - Recommend Rewrite 




E707 Media: Error With OTF Correction - Recommend Rewrite 

1 

17 

09 

Recovered Data Without LDPC - Data Rewritten 




E708 Media: Error With OTF Correction - Rewritten 

1 

18 

00 

Recovered Data With LDPC 




1709 Media: Recovered Error With Offline Correction 




17AE Media: Recovered ECC Correctable Error 

1 

18 

02 

Recovered Data - Data Auto-Reallocated 




D70A Media: Error With Offline Correction - Reassigned 

1 

18 

05 

Recovered Data - Recommend Reassignment 




E70B Media: Error With Offline Correction - Recommend Reassign 

1 

18 

06 

Recovered Data With LDPC - Recommend Rewrite 




E70C Media: Error With Offline Correction - Recommend Rewrite 

1 

18 

07 

Recovered Data With LDPC - Data Rewritten 




E70D Media: Error With Offline Correction - Rewritten 

1 

1C 

00 

Defect List Format Not Supported 




1746 Media: Recovered Defect List Format Not Supported Error 

1 

1C 

01 

Primary Defect List Not Found. Requested Format Not Supported 




1747 Media: Recovered Primary Defect List Not Found Error 

1 

1C 

02 

Grown Defect List Not Found. Requested Format Not Supported 




1748 Media: Recovered Grown Defect List Not Found Error 

1 

IF 

00 

Partial Defect List Transfer 




1749 Media: Recovered Partial Defect List Transferred Error 

1 

44 

00 

Internal Target Failure 




FI32 GEM FH track read error 




1201 Sanity: Error In UEC Class 




1202 Sanity: Error In UEC Cause 




1301 Motor: Recovered internal error 




1303 Motor: Recovered Open Loop Commutation failure 
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1305 Motor: Recovered No feedback detected error 




1307 Motor: Recovered Settle timeout 




1309 Motor: Recovered Gross speed error 




130B Motor: Recovered 12V OK error 




130D Motor: Recovered Speed error 




1311 Motor: Recovered Internal 12V not OK timeout 




1313 Motor: Recovered Inductive Sense measurement timeout 




1315 Motor: Recovered Spin Sense speed error 




1319 Motor: Recovered Target speed error 




F31B Motor: Unrecovered Power driver version error 




131D Motor: Recovered Over current error 




1321 Motor: Recovered Negative regulator fault 




1323 Motor: Recovered Module overtemp error 




1325 Motor: Recovered 12V or 5V OK error 




1327 Motor: Recovered unknown error 




1365 Motor: Recovered Predriver Voltage Offset Calibration Error 




1367 Motor: Recovered Predriver BEMF Gain Calibration Error 




1369 Motor: Recovered Predriver BEMF Unload Calibration Error 




1401 Servo: Recovered Requested rezero head does not exist 




1403 Servo: Recovered Back EMF movement in progress 




1405 Servo: Recovered Back EMF timeout error 




1407 Servo: Recovered ADC conversion timeout 




1409 Servo: Recovered Load/unload calibration error 




140B Servo: Recovered Invalid 5 volts 




140D Servo: Recovered Invalid 12 volts 




140F Servo: Recovered Invalid harmonic requested 




1411 Servo: Recovered Gain BEMF Calibration error 




1413 Servo: Recovered VOFF BEMF calibration error 




1415 Servo: Recovered Invalid temperature 




1417 Servo: Recovered Truncated rezero 




1419 Servo: Recovered Heads not loaded 




1425 Servo: Recovered KT Seek out of range 




1427 Servo: Recovered DAC Offset calibration error 




1429 Servo: Recovered Load speed error 




142D Servo: Recovered ADC Calibration error 




142F Servo: Recovered ADC Offset error 




1431 Servo: Recovered ADC Limit error 




1433 Servo: Recovered Balancer Resistance error 




1435 Servo: Recovered Balancer Resistance Limit error 




1437 Servo: Recovered First Cylinder error 




1439 Servo: Recovered Valid Cylinder error 




143B Servo: Recovered ADC Saturation error 




143D Servo: Recovered Latch Break timeout 




143F Servo: Recovered MR Resistance out of range error 




1441 Servo: Recovered VCM Retract error 
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1443 Servo: Recovered Load Retry error 




1445 Servo: Recovered DFT Sharp error 




1447 Servo: Recovered Load/Unload state error 




1449 Servo: Recovered TFCR out-of-range error 




144B Servo: Recovered Measure GMR Timeout 




144D Servo: Recovered Coil Resistance Measurement Failure 




145F Servo: Recovered WCS Hang Error 




1461 Servo: Recovered DFT Timeout Error 




1463 Servo: Recovered SDM Timeout Error 




1465 Servo: Recovered RRO Write Error 




1467 Servo: Recovered Velocity Error 




1469 Servo: Recovered Start SID Incorrect Error 




146B Servo: Recovered End Sid Incorrect Error 




146D Servo: Recovered Measure GMR SDM Failure 




146F Servo: Recovered VCM Free Speed Error 




1471 Servo: Recovered Emergency Brake Timeout Error 




1473 Servo: Recovered Excessive Current Error 




1475 Servo: Recovered Excessive Velocity Error 




147D Servo: Recovered RROF SDM Timeout Error 




147F Servo: Recovered RROF Over Limit Error 




1482 Servo: Recovered Measure Asymmetry SDM Failure 




1486 Servo: Recovered Milli-Calibration Error 




148C Servo: Recovered Measure Qsamp SDM Failure 




1606 AE: Recovered AE Last Data Read Error 




1609 AE: Recovered TFC Short Error 




160B AE: Recovered Shorted MR Element Error 




1610 AE: Recovered ECS Shorted Fault 




1612 AE: Recovered ECS Open Fault 




1614 AE: Recovered ECS Fault 




1616 Channel: Recovered Channel Error 




1618 AE: Recovered AE Thermal Asperity Found Error 




161AAE: Recovered Open MR Element Error 




161 CAE: Recovered 1C Over Temperature Error 




161EAE: Recovered IP Clock Count Error 




1620 AE: Recovered High MR Current Error 




1622 AE: Recovered Write Data BLS Error 




1624 AE: Recovered Invalid Head Address Error 




1626 AE: Recovered Power Supply Error 




1628 AE: Recovered Open Write Head Error 




162AAE: Recovered Write Transition Error 




162C AE: Recovered No Write Head Current Error 




162E Channel: Recovered Channel NRZ Clear Timeout Error 




1630 AE: Recovered SPE Low In Write Fault 




1634 AE: Recovered Short Write Read Head Error 




1636 AE: Recovered Short Write Head Error 
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1638 AE: Recovered Non-Selected Write Head Error 




163AAE: Recovered Write Current In Read Error 




163C AE: Recovered TFC Open Error 




163E AE: Recovered IH Delay Error 




1640 AE: Recovered Write Head Encode Error 




1642 AE: Recovered Read back Error 




1644 AE: Recovered Latch Fault Error 




1646 AE: Recovered Write Gate During Idle Fault 




1648 Channel: Recovered Reset Flag Error 




164A Channel: Recovered Split Fault Error 




164C Channel: Recovered Sector Size Fault Error 




164E Channel: Recovered Last Split Fault Error 




1650 Channel: Recovered Servo-Servo Overlap Error 




1652 Channel: Recovered Read Gate Fault Error 




1654 Channel: Recovered RWBI Out Fault Error 




1656 Channel: Recovered No Write Clock Error 




1658 Channel: Recovered No NRZ Clock Error 




165A Channel: Recovered Calibration Block Fault Error 




165C Channel: Recovered Mode Overlap Fault Error 




165E Channel: Recovered Preamble Fault Error 




1660 Channel: Recovered WPLO Fault Error 




1662 Channel: Recovered Write Gate Overlap Fault Error 




1664 Channel: Recovered Write Gate Fault Error 




1666 Channel: Recovered Buffer Overflow Write Error 




1668 Channel: Recovered Buffer Underflow Write Error 




166A Channel: Recovered Write Parity Error 




166C Channel: Recovered Buffer Overflow Read Error 




166E Channel: Recovered Buffer Underflow Read Error 




1670 Channel: Recovered RPLO Late Error 




1672 Channel: Recovered Bit Count Late Error 




1674 Channel: Recovered Preamp Count Fault Error 




1676 Channel: Recovered Pfault Read Error 




1678 Channel: Recovered Pfault Write Error 




167A Channel: Recovered Last Data Fault Error 




167C Channel: Recovered WRPO Fault Error 




167E Channel: Recovered Forced Channel Fault Error 




1680 Channel: Recovered PLLFIoor Error 




1682 Channel: Recovered Loss lock Error 




1684 Channel: Recovered VGA Floor Error 




1686 Channel: Recovered Buffer EVGA Floor Error 




1688 Channel: Recovered TA Detector Error 




168A Channel: Recovered NPLD Error 




168C Channel: Recovered ZGR Flag Error 




168E Channel: Recovered DPLL Freq Flag Error 




1690 Channel: Recovered MDO Detection Error 
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1692 Channel: Recovered TAEP Flag Error 




1694 Channel: Recovered Flaw Signal Sync Error 




1696 Channel: Recovered ACQ Flag Error 




1698 Channel: Recovered No Clock Error 




169A Channel: Recovered PLL Loss lock Error 




169C Channel: Recovered ESNR Timeout Error 




169E Channel: Recovered ADC Sample Not Ready Error 




16A2 Channel: Recovered Auto RST NRZ-Clock Error 




16A4 Channel: Recovered Write CRC Fault Error 




16A6 Channel: Recovered Synchronous Loss Lock Error 




16A8 Channel: Recovered RLL Parameter Error 




16AA Channel: Recovered FIFO Underflow Error 




16AC Channel: Recovered FIFO Overflow Error 




16AE Channel: Recovered Iterative Decoder Error 




16B0 Channel: Recovered Iterative Read Error 




16B2 Channel: Recovered Encoder Overflow Error 




16B4 Channel: Recovered Encoder Underflow Error 




16B6 Channel: Recovered Encoder RAM CRC Error 




16B8 Channel: Recovered Interface Fault 




16BA Channel: Recovered QMM EVDump Parse Error 




16BC Channel: Recovered DiBit Timeout Error 




16C0 Channel: Recovered Data Jam Error 




16C2 Channel: Recovered Code-Word Out Of Order Error 




1712 Media: Recovered LBAMEDC Error 




1716 Media: Recovered Write Overrun Error 




171C Media: Recovered DRAM CRC Error 




1731 Media: Recovered Write Fault 




1744 Media: Recovered Sudden Stop Error 




1759 Media: Recovered Unknown Error 




1766 Channel: Recovered XTS LOAD Timeout Error 




176A Media: Recovered No NRZ Clock Error 




176E Media: Correctable Channel Ready Error 




1786 Media: Recovered LLI Underrun Error 




1792 Media: Recovered MEDC Write Data Not Ready Error 




1794 Media: Recovered DMA Timeout Error 




1798 Media: Recovered ID Not Found Error 




179C Media: Recovered Channel Read Timeout Error 




17B4 Media: Recovered Shock Sensor Error 




17C0 Media: Recovered End Sector Check Error 




17C2 Media: Recovered Read CRC Error 




17C4 Media: Recovered DRAM ECC Error 




17C6 Media: Recovered DRAM ECC LBA Error 




17D4 Media: Recovered Parity PTR FIFO Error 




17D6 Media: Recovered Parity LBA FIFO Error 




17D8 Media: Recovered Parity Uncorrectable FIFO Error 
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17DA Media: Recovered Status Uncorrectable FIFO Error 




17DC Media: Recovered Parity EDO SRAM Error 




17DE Media: Recovered REQ/ACK Handshake Error 




17E2 Media: Recovered Read Parity Error 




17E4 Media: Recovered EPO Error 




17E8 Media: Recovered AE Access Inhibit Error 




17EA Media: Recovered PTR FIFO Error 




17EC Media: Recovered LBA FIFO Error 




17F0 Media: Recovered Read Transfer Length Error 




17F2 Media: Recovered DS RDC Burst Error 




17F4 Media: Recovered SV RDC Burst Error 

1 

44 

OB 

Vendor Unique - Internal Target Failure 




130F Motor: Recovered Spindle Current error 




1317 Motor: Recovered Spin Sense timeout 




131F Motor: Recovered System clock watchdog error 




1329 Motor: Recovered VCM DAC watchdog error 




132B Motor: Recovered Module mid-die overtemp fault 




132D Motor: Recovered Module Vcmp hi-side overtemp fault 




132F Motor: Recovered Module Vcmn hi-side overtemp fault 




1331 Motor: Recovered Invalid standby RPM request 




1333 Motor: Recovered Invalid spin state request 




1335 Motor: Recovered Hardware retract timeout 




1337 Motor: Recovered thermal limit exceeded 




1339 Motor: Recovered Predriver fault 




133B Motor: Recovered Predriver Watchdog Fsys error 




133D Motor: Recovered Predriver Watchdog DAC error 




133F Motor: Recovered Predriver Speed Low error 




1341 Motor: Recovered Predriver UV Vboost error 




1343 Motor: Recovered Predriver NREG UV error 




1345 Motor: Recovered Predriver Ext NPOR error 




1347 Motor: Recovered Predriver Reg UV error 




1349 Motor: Recovered Predriver Under Voltage 12 Volt Supply error 




134B Motor: Recovered Predriver Under Voltage 5 Volt Supply error 




134D Motor: Recovered Predriver Over Voltage 12 Volt Supply error 




134F Motor: Recovered Predriver Under Voltage 1.8 Volt Supply error 




1351 Motor: Recovered Predriver Under Voltage 0.9 Volt Supply error 




1353 Motor: Recovered Predriver Under Voltage 1.5 Volt Supply error 




1355 Motor: Recovered Predriver Shock Detected error 




1357 Motor: Recovered Predriver Over Temperature error 




1359 Motor: Recovered Predriver Under Voltage 3.3 Volt Supply error 




135B Motor: Recovered Predriver Under Voltage 5 and 12 Volt Supply error 




135D Motor: Recovered Predriver Error in Enabling Power Saving Mode 




135F Motor: Recovered Predriver Fault in Auto Retract 




1361 Motor: Recovered Predriver Error in Utilizing External Power Supply 




1363 Motor: Recovered Predriver Regulator Supply Fault 
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1 

44 

F9 

Vendor Unique - Internal Target Failure 




144F Servo: Recovered SHARP Parity Error 




1451 Servo: Recovered SHARP Parity Rate Error 




1453 Servo: Recovered SHARP Decode Error 




1455 Servo: Recovered SHARP Decode Rate Error 




1457 Servo: Recovered SHARP Timeout Error 




1459 Servo: Recovered SHARP Timeout Rate Error 




145B Servo: Recovered SHARP Other Error 




145D Servo: Recovered SHARP Other Rate Error 

1 

5D 

01 

Self Test Error 




1A85 Self-Test: Recovery Error 




2A85 Self-Test: Servo Error 




4A85 Self-Test: Command Timeout Error 




FA85 Self-Test: Unrecoverable Error 

1 

5D 

14 

Self Test GUST Error Threshold Reached 




2A83 Self-Test: GUST Error Count Threshold Reached 

1 

81 

00 

Vendor Unique - Internal Logic Error 




1601 Channel/AE: Recovered Internal Logic Error 

Sense Key = Not Ready 

2 

04 

00 

Logical Unit Not Ready - Start Spindle Motor Fail 




F501 Host Interface: Logical unit not ready 

2 

04 

01 

Logical Unit Is In The Process of Becoming Ready 




F502 Host Interface: Logical unit becoming ready 

2 

04 

02 

Logical Unit Not Ready, initializing command required 




FI 24 Bring-up error 




F503 Host Interface: Logical unit not ready - initializing command required 

2 

04 

03 

Logical Unit Not Ready, Manual Intervention Required 




F572 Host Interface: LUN not ready; manual intervention required 

2 

04 

04 

Logical Unit Not Ready, Format In Progress 




F504 Host Interface: Not ready - format in progress 

2 

04 

09 

Not Ready - Self-test In Progress 




F505 Host Interface: Not ready - self-test in progress 

2 

04 

0D 

Not Ready - Session opened 




F508 Host Interface: Not Ready - Session opened 

2 

04 

11 

Not Ready - Notify (Enable Spin-up) Required 




F553 Host Interface: LUN Not ready, Notify (Enable Spinup) required (SAS) 

2 

04 

IB 

Host Interface Not Ready - Sanitize In Progress 




F50B Host Interface: Not Ready - Sanitize in progress 

2 

04 

F0 

Vendor Unique - Logical Unit Not Ready 




F133 BATS error: Vendor ID mismatch 




F54C Host Interface: LUN Not Ready - Super Certify in Progress 

2 

31 

00 

Medium Format Corrupted - Reassign Failed 




F506 Host Interface: Reassign failed 

2 

31 

01 

Format Command Failed 




F507 Host Interface: Format failed 




Sense Key = Medium Error 

3 

03 

00 

Medium Error - Write Fault 
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F734 Media: Unrecovered Read Write Abort Error 




F738 Media: Unrecovered Post Write Abort 




F73A Media: Unrecovered Post PES Check Write Abort Error 




F797 Media: SAT Write Abort 




F7E1 Media: Unrecovered Write Splice Error 




FED7 Media: Unrecovered R/W Abort Off Track Write Error 




FED9 Media: Unrecovered R/W Abort RRO Field Misread Error 




FEDB Media: Unrecovered R/W Abort RRO Field Missing Error 




FEDD Media: Unrecovered R/W Abort Idle Seek Error 




FEDF Media: Unrecovered R/W Abort Seek Timeout Error 




FEE1 Media: Unrecovered R/W Abort Estimator Error 




FEE3 Media: Unrecovered R/W Abort Predictor Error 




FEE5 Media: Unrecovered R/W Abort PES Error 




FEE7 Media: Unrecovered R/W Abort Seek Start Error 




FEE9 Media: Unrecovered R/W Abort PES Reset Error 




FEEB Media: Unrecovered R/W Abort SID Unlock Error 




FEED Media: Unrecovered R/W Abort WCS Error 




FEEF Media: Unrecovered R/W Abort Hard Reset Error 




FEF1 Media: Unrecovered R/W Abort Shock Error 




FEF3 Media: Unrecovered R/W Abort Unlock Macro Error 




FEF5 Media: Unrecovered R/W Abort Sharp Error 




FEF7 Media: Unrecovered R/W Abort Aggressive Error 




FEF9 Media: Unrecovered R/W Abort SVGA Limit Error 




FEFB Media: Unrecovered R/W Abort Gray Code Error 




FEFD Media: Unrecovered R/W Abort Burst Error 




FEFF Media: Unrecovered R/W Abort No STM Error 

3 

OA 

01 

Unrecovered Super Certification Log Write Error 




F7AC Media: Unrecovered Super Certification Log Write Error 

3 

OA 

02 

Unrecovered Super Certification Log Read Error 




F7AD Media: Unrecovered Super Certification Log Read Error 

3 

11 

00 

Unrecovered Read Error 




F702 Too many notches 




F72D Media: Unrecovered Uncorrectable Read Data error 




F72F Media: Unrecovered Error on Last Data Read 




F730 Media: Recommend targeted scan 




F74A Media: Unrecovered Alternate Track Table Full Error 




F74D Media: Unrecovered Too Many Heads Error 




F74E Media: Unrecovered Skew Table Size Error 




F74F Media: Unrecovered Too Many Zones Error 




F750 Media: Unrecovered Too Many SIDs Error 




F751 Media: Unrecovered Alternate Track Table Full Error 




F752 Media: Unrecovered Drive Capacity Too Small 




F753 Media: Unrecovered G-list Full (Format command) 




F754 Media: Unrecovered G-list Full (2) (Format command) 




F755 Media: Unrecovered Pointer Repeat Size Error 


HGST Hard Disk Drive OEM Specification 
337 












F756 Media: Unrecovered DST Slot Size Error 




F757 Media: Unrecovered P-list Full Error 




F758 Media: Unrecovered Spare List Full Error 




F75E Media: Unrecovered Maximum Servo Cylinder Number Too Small Error 




F76D Media: Unrecovered MEDC Uncorrectable Error 




F783 Media: Unrecovered Force Soft Error 




F785 Media: Unrecovered Channel Sector Marginal Error 




F7CE Media: Unrecovered Offline Already TAR Error 




F7E7 Media: Unrecovered NRZ Sector Marginal Error 

3 

11 

14 

Unrecovered LBA Error 




F7CA Media: Unrecovered LBA Correction Disabled Error 




F7CC Media: Unrecovered LBA Write Uncorrectable Error 

3 

15 

00 

Random Positioning Error 




F715 Media: Unrecovered Sector Overflow Error 




F73E Media: Unrecovered Sector Miss Error 




F771 Media: Unrecovered SID Timeout Error 




F7B3 Media: Unrecovered Abort Window Error 




F7EF Media: Unrecovered Sector Number Cylinder Error 

3 

15 

03 

Unrecovered Sector Error 




F7AF Media: Unrecovered Sector Missing Error 




F7B0 Media: Unrecovered Sector Overflow 

3 

16 

00 

Data Synchronization Mark Error 




F736 Channel: Unrecovered No Sync Detected Error 




F73C Media: Unrecovered Data Address Mark Error 




F7AA Media: Unrecovered Read Overrun Error 

3 

19 

02 

Defect List Error in Primary List 




F74B Media: Unrecovered Primary Defect List Error 

3 

19 

03 

Defect List Error in Grown List 




F74C Media: Unrecovered Grown Defect List Error 

3 

31 

00 

Medium Format Corrupted Reassign Failed 




F701 Format corrupted 

3 

31 

03 

Sanitize Command failed 




F50C Host Interface: Sanitize Command failed 

3 

40 

00 

Unrecovered SAT No Buffer Overflow Error 




F75F Media: Unrecovered SAT No Buffer Overflow Error 

3 

40 

01 

Unrecovered SAT Buffer Overflow Error 




F760 Media: Unrecovered SAT Buffer Overflow Error 

3 

40 

02 

Unrecovered SAT No Buffer Overflow With ECS Fault 




F78E Media: Unrecovered SAT No Buffer Overflow With ECS Fault 

3 

40 

03 

Unrecovered SAT Buffer Overflow With ECS Fault 




F78F Media: Unrecovered SAT Buffer Overflow With ECS Fault 

3 

5D 

01 

Self Test Unrecoverable Error Threshold Exceeded 




FA81 Self-Test: Unrecoverable Error Count Threshold Exceeded 

3 

81 

00 

Vendor Unique - Internal Logic Error 




F75B Media: Unrecovered Too Many Sectors Error 
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Sense Key = Hardware Error 

4 

02 

00 

No Seek Complete 




F41C Servo: Unrecovered Current error 




F41E Servo: Unrecovered Seek timeout 




F420 Servo: Unrecovered Seek error 




F42C Servo: Unrecovered RRO Calibration timeout 

4 

09 

00 

Track Following Error 




F422 Servo: Unrecovered Track following error 




F424 Servo: Unrecovered Track follow timeout 

4 

31 

00 

Medium Format Corrupted - Reassign Failed 




F204 Reassign reserved area media error 

4 

32 

00 

No Defect Spare Location Available 




F205 G-list full - can't reassign any more sectors 




F206 No spares available 

4 

3E 

03 

Self-test Failed 




F481 Servo: Unrecovered Self-Test Failed 




F75D Media: Unrecovered Self-Test Failed Error 

4 

3E 

04 

Unrecovered Self-Test Hard-Cache Test Fail 




F762 Media: Unrecovered Self-Test Hard-Cache Test Fail 

4 

3E 

05 

Unrecovered Self-Test OTF-Cache Fail 




F763 Media: Unrecovered Self-Test OTF-Cache Fail 

4 

40 

80 

Diagnostic Failure 




FI 01 BATS error: Reserved Area - Invalid request 




FI 02 BATS error: Reserved Area - Broken 




FI 03 BATS error: Reserved Area - Invalid version 




FI 04 BATS error: Reserved Area - Invalid checksum 




FI 05 BATS error: Reserved Area - Invalid eye catcher 




FI 06 BATS error: Reserved Area - Invalid main header checksum 




FI 07 BATS error: Reserved Area - Invalid read length 




FI 08 BATS error: Reserved Area - Address boundary error 




FI 0D BATS error: Reserved Area - Write fix hard error 




F10E BATS error: Directory broken 




Fill BATS error: RAM code load error 




F112 BATS error: RAM code check 




FI ID BATS error: Incorrect Disk Code 




F125 BATS error: Invalid RID/FID 




F12B BATS error: Reserved area - invalid model 




F12C BATS error: Invalid code size 




FI 2D Format Reserved: FAT Size Exceeded Error 




F12E Format Reserved: Insufficient DIRS Good Error 




F12F Format Reserved: Insufficient FATS Good Error 




F131 Flash timeout 




FI 37 Flash ECC error 




F138 BATS error: ATI RID Error 




FI39 Format Reserved: Resize RID/FID Error 




F13A BATS error: RSEC Read Error 
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F13B BATS error: SW Target broken 




F13C BATS error: NODE DRAM failure 




FI 40 Format Reserved: Too many Defects Error 

4 

40 

81 

DRAM Failure 




F12A DRAM test error 

4 

40 

90 

Diagnostic Failure 




F118 BATS#2 error: Seek test error 

4 

40 

91 

Diagnostic Failure 




F13E BATS#2 error: TCG Test Failed 

4 

40 

AO 

Diagnostic Failure 




F119 BATS#2 error: Read/write test error 




F11B BATS#2 error: CRC test error 




F11C BATS#2 error: XOR test error 




FI 36 BATS#2 error: End-To-End Data Protection error 




F13F BATS#2 error: Read/Write Test Compare Failed 

4 

44 

00 

Internal Target Failure 




F203 Sanity: Sanity Check Failure 




F208 Mode Page Structure Mismatch 




F209 Miscompare of SBA in the P-List 




F20A Error Clearing Reset State 




F302 Motor: Unrecovered internal error 




F304 Motor: Unrecovered Open Loop Commutation failure 




F306 Motor: Unrecovered No feedback detected error 




F308 Motor: Unrecovered Settle timeout 




F30A Motor: Unrecovered Gross speed error 




F30C Motor: Unrecovered 12V OK error 




F30E Motor: Unrecovered Speed error 




F312 Motor: Unrecovered Internal 12V not OK timeout 




F314 Motor: Unrecovered Inductive Sense speed error 




F316 Motor: Unrecovered Spin Sense speed error 




F31A Motor: Unrecovered Target speed error 




F31C Motor: Unrecovered Power driver version error 




F31E Motor: Unrecovered Over current error 




F322 Motor: Unrecovered Negative regulator fault 




F324 Motor: Unrecovered Module overtemp error 




F326 Motor: Unrecovered 12V or 5V OK error 




F328 Motor: Unrecovered unknown error 




F366 Motor: Unrecovered Predriver Voltage Offset Calibration Error 




F368 Motor: Unrecovered Predriver BEMF Gain Calibration Error 




F36A Motor: Unrecovered Predriver BEMF Unload Calibration Error 




F402 Servo: Unrecovered Requested rezero head does not exist 




F404 Servo: Unrecovered Back EMF movement in progress 




F406 Servo: Unrecovered Back EMF timeout error 




F408 Servo: Unrecovered ADC conversion timeout 




F40A Servo: Unrecovered Load/unload calibration error 




F40C Servo: Unrecovered Invalid 5 volts 
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F40E Servo: Unrecovered Invalid 12 volts 




F410 Servo: Unrecovered Invalid harmonic requested 




F412 Servo: Unrecovered Gain BEMF Calibration error 




F414 Servo: Unrecovered VOFF BEMF calibration error 




F416 Servo: Unrecovered Invalid temperature 




F418 Servo: Unrecovered Truncated rezero 




F41AServo: Unrecovered Heads not loaded 




F426 Servo: Unrecovered KT Seek out of range 




F428 Servo: Unrecovered DAC Offset calibration error 




F42A Servo: Unrecovered Load speed error 




F42E Servo: Unrecovered ADC Calibration error 




F430 Servo: Unrecovered ADC Offset error 




F432 Servo: Unrecovered ADC Limit error 




F434 Servo: Unrecovered Balancer Resistance error 




F436 Servo: Unrecovered Balancer Resistance Limit error 




F438 Servo: Unrecovered First Cylinder error 




F43A Servo: Unrecovered Valid Cylinder error 




F43C Servo: Unrecovered ADC Saturation error 




F43E Servo: Unrecovered Latch Break timeout 




F440 Servo: Unrecovered MR Resistance out of range error 




F442 Servo: Unrecovered VCM Retract error 




F444 Servo: Unrecovered Load Retry error 




F446 Servo: Unrecovered DFT Sharp error 




F448 Servo: Unrecovered Load/Unload state error 




F44A Servo: Unrecovered TFCR out-of-range error 




F44C Servo: Unrecovered Measure GMR Timeout 




F44E Servo: Unrecovered Coil Resistance Measurement Failure 




F460 Servo: Unrecovered WCS Hang Error 




F462 Servo: Unrecovered DFT Timeout Error 




F464 Servo: Unrecovered SDM Timeout Error 




F466 Servo: Unrecovered RRO Write Error 




F468 Servo: Unrecovered Velocity Error 




F46A Servo: Unrecovered Start SID Incorrect Error 




F46C Servo: Unrecovered End Sid Incorrect Error 




F46E Servo: Unrecovered Measure GMR SDM Failure 




F470 Servo: Unrecovered VCM Free Speed Error 




F472 Servo: Unrecovered Emergency Brake Timeout Error 




F474 Servo: Unrecovered Excessive Current Error 




F476 Servo: Unrecovered Excessive Velocity Error 




F477 Servo: Unrecovered Invalid SDM CDB Error 




F478 Servo: Unrecovered Invalid SDM Descriptor Error 




F479 Servo: Unrecovered Invalid DFT Descriptor Error 




F47A Servo: Unrecovered SDM or DFT Allocation Error 




F47B Servo: Unrecovered SDM OR DFT Transfer Error 




F47C Servo: Unrecovered SDM Physical Parameter Error 
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F47E Servo: Unrecovered RROF SDM Timeout Error 




F480 Servo: Unrecovered RROF Over Limit Error 




F483 Servo: Unrecovered Measure Asymmetry SDM Failure 




F484 Servo: Unrecovered Measure Overwrite SDM Failure 




F485 Servo: Unrecovered TFC Utility SDM Failure 




F487 Servo: Unrecovered Milli-Calibration Error 




F488 Servo: Unrecovered SIDSAT Timeout Error 




F489 Servo: Unrecovered SDM Load-And-Drop-Anchor Error 




F48A Servo: Unrecovered Filter Table Full Error 




F48B Servo: Unrecovered Filter Table Invalid Error 




F48D Servo: Unrecovered Measure Qsamp SDM Failure 




F603 Channel/AE: Unrecovered Internal Target Failure 




F604 Channel/AE: Unrecovered Internal Calibration Error 




F605 Channel/AE: Unrecovered Internal MR Calibration Error 




F607 Channel/AE: Unrecovered data with PPM or precomp load 




F60A AE: TFC Short Error 




F60C AE: Unrecovered Shorted MR Element Error 




F60D Unsupported Read Channel Command Error 




F60E Init: RRCIk Dead Error 




F60F Init: RRCIk Unlock Error 




F611 AE: Unrecovered ECS Shorted Fault 




F613 AE: Unrecovered ECS Open Fault 




F615 AE: Unrecovered ECS Fault 




F617 Channel: Unrecovered Channel Error 




F619 AE: U n recove red A E Thermal Asperity Found Error 




F61B AE: Unrecovered Open MR Element Error 




F61D AE: Unrecovered 1C Over Temperature Error 




F61F AE: Unrecovered IP Clock Count Error 




F621 AE: Unrecovered High MR Current Error 




F623 AE: Unrecovered Write Data BLS Error 




F625 AE: Unrecovered Invalid Head Address Error 




F627 AE: Unrecovered Power Supply Error 




F629 AE: Unrecovered Open Write Head Error 




F62B AE: Unrecovered Write Transition Error 




F62D AE: Unrecovered No Write Head Current Error 




F631 AE: Unrecovered SPE Low In Write Fault 




F633 Channel: Unrecovered Write Synth Unlock error 




F635 AE: Unrecovered Short Write Read Head Error 




F637 AE: Unrecovered Short Write Head Error 




F639 AE: Unrecovered Non-Selected Write Head Error 




F63B AE: Unrecovered Write Current In Read Error 




F63D AE: Unrecovered TFC Open Error 




F63F AE: Unrecovered IH Delay Error 




F641 AE: Unrecovered Write Head Encode Error 




F643 AE: Unrecovered Read back Error 
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F645 AE: Unrecovered Latch Fault Error 




F647 AE: Unrecovered Write Gate During Idle Fault 




F649 Channel: Unrecovered Reset Flag Error 




F64B Channel: Unrecovered Split Fault Error 




F64D Channel: Unrecovered Sector Size Fault Error 




F64F Channel: Unrecovered Last Split Fault Error 




F651 Channel: Unrecovered Servo-Servo Overlap Error 




F653 Channel: Unrecovered Read Gate Fault Error 




F655 Channel: Unrecovered RWBI Out Fault Error 




F657 Channel: Unrecovered No Write Clock Error 




F659 Channel: Unrecovered No NRZ Clock Error 




F65B Channel: Unrecovered Calibration Block Fault Error 




F65D Channel: Unrecovered Mode Overlap Fault Error 




F65F Channel: Unrecovered Preamble Fault Error 




F661 Channel: Unrecovered WPLO Fault Error 




F663 Channel: Unrecovered Write Gate Overlap Fault Error 




F665 Channel: Unrecovered Write Gate Fault Error 




F667 Channel: Unrecovered Buffer Overflow Write Error 




F669 Channel: Unrecovered Buffer Underflow Write Error 




F66B Channel: Unrecovered Write Parity Error 




F66D Channel: Unrecovered Buffer Overflow Read Error 




F66F Channel: Unrecovered Buffer Underflow Read Error 




F671 Channel: Unrecovered RPLO Late Error 




F673 Channel: Unrecovered Bit Count Late Error 




F675 Channel: Unrecovered Preamp Count Fault Error 




F677 Channel: Unrecovered Pfault Read Error 




F679 Channel: Unrecovered Pfault Write Error 




F67B Channel: Unrecovered Last Data Fault Error 




F67D Channel: Unrecovered WRPO Fault Error 




F67F Channel: Unrecovered Forced Channel Fault Error 




F681 Channel: Unrecovered PLLFIoor Error 




F683 Channel: Unrecovered Loss lock Error 




F685 Channel: Unrecovered VGA Floor Error 




F687 Channel: Unrecovered Buffer EVGA Floor Error 




F689 Channel: Unrecovered TA Detector Error 




F68B Channel: Unrecovered NPLD Error 




F68D Channel: Unrecovered ZGR Flag Error 




F68F Channel: Recovered DPLL Freq Flag Error 




F691 Channel: Unrecovered MDO Detection Error 




F693 Channel: Unrecovered TAEP Flag Error 




F695 Channel: Unrecovered Flaw Signal Sync Error 




F697 Channel: Unrecovered ACQ Flag Error 




F699 Channel: Unrecovered No Clock Error 




F69B Channel: Unrecovered PLL Loss lock Error 




F69D Channel: Unrecovered ESNR Timeout Error 
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F69F Channel: Unrecovered ADC Sample Not Ready Error 




F6A0 AE: Unrecovered Fuse Load Fail Error 




F6A1 AE: Unrecovered Configuration Error 




F6A3 Channel: Unrecovered Auto RST NRZ-Clock Error 




F6A5 Channel: Unrecovered Write CRC Fault Error 




F6A7 Channel: Unrecovered Synchronous Loss Lock Error 




F6A9 Channel: Unrecovered RLL Parameter Error 




F6AB Channel: Unrecovered FIFO Underflow Error 




F6AD Channel: Unrecovered FIFO Overflow Error 




F6AF Channel: Unrecovered Iterative Decoder Error 




F6B1 Channel: Unrecovered Iterative Read Error 




F6B3 Channel: Unrecovered Encoder Overflow Error 




F6B5 Channel: Unrecovered Encoder Underflow Error 




F6B7 Channel: Unrecovered Encoder RAM CRC Error 




F6B9 Channel: Unrecovered Interface Fault 




F6BB Channel: Unrecovered QMM EVDump Parse Error 




F6BD Channel: Unrecovered DiBit Timeout Error 




F6BE Channel: Unrecovered Insufficient TFC Heat Error 




F6C1 Channel: Unrecovered Data Jam Error 




F6C3 Channel: Unrecovered Code-Word Out Of Order Error 




F6C4 AEQ: Timeout Error 




F6C5 AEQ: NLD Initialization Timeout Error 




F6C6 Channel: Unrecovered ADC Calibration Timeout Error 




F6C7 Channel: Unrecovered ADC Buffer Calibration Timeout Error 




F6C8 Channel: Unrecovered Power Sequence Timeout Error 




F713 Media: Unrecovered LBAMEDC Error 




F717 Media: Unrecovered Write Overrun Error 




F71D Media: Unrecovered DRAM CRC Error 




F732 Media: Unrecovered Write Fault 




F745 Media: Unrecovered Sudden Stop Error 




F75A Media: Unrecovered Unknown Error 




F767 Channel: Unrecovered XTS LOAD Timeout Error 




F76B Media: Unrecovered No NRZ Clock Error 




F76F Media: Uncorrectable Channel Ready Error 




F787 Media: Unrecovered LLI Underrun Error 




F793 Media: Unrecovered MEDC Write Data Not Ready error 




F795 Media: Unrecovered DMA Timeout Error 




F799 Media: Unrecovered ID Not Found Error 




F79D Media: Unrecovered Channel Read Timeout Error 




F7B5 Media: Unrecovered Shock Sensor Error 




F7C1 Media: Unrecovered End Sector Check Error 




F7C3 Media: Unrecovered Read CRC Error 




F7C5 Media: Unrecovered DRAM ECC Error 




F7C7 Media: Unrecovered DRAM ECC LBA Error 




F7CD Media: Unrecovered LBA Encryption Error 
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F7D5 Media: Unrecovered Parity PTR FIFO Error 




F7D7 Media: Unrecovered Parity LBA FIFO Error 




F7D9 Media: Unrecovered Parity Uncorrectable FIFO Error 




F7DB Media: Unrecovered Status Uncorrectable FIFO Error 




F7DD Media: Unrecovered Parity EDO SRAM Error 




F7DF Media: Unrecovered REQ/ACK Handshake Error 




F7E3 Media: Unrecovered Read Parity Error 




F7E5 Media: Unrecovered EPO Error 




F7E9 Media: Unrecovered AE Access Inhibit Error 




F7EB Media: Unrecovered PTR FIFO Error 




F7ED Media: Unrecovered LBA FIFO Error 




F7F1 Media: Unrecovered Read Transfer Length Error 




F7F3 Media: Unrecovered DS RDC Burst Error 




F7F5 Media: Unrecovered SV RDC Burst Error 




FCxx Media: Unrecovered Unable to Read RID or FID Number xx 

4 

44 

OB 

Vendor Unique - Internal Target Failure 




F310 Motor: Unrecovered Spindle Current error 




F318 Motor: Unrecovered Spin Sense timeout 




F320 Motor: Unrecovered System clock watchdog error 




F32A Motor: Unrecovered VCM DAC watchdog error 




F32C Motor: Unrecovered Module mid-die overtemp fault 




F32E Motor: Unrecovered Module Vcmp hi-side overtemp fault 




F330 Motor: Recovered Module Vcmn hi-side overtemp fault 




F332 Motor: Unrecovered Invalid standby RPM request 




F334 Motor: Unrecovered Invalid spin state request 




F336 Motor: Unrecovered Hardware retract timeout 




F338 Motor: Unrecovered thermal limit exceeded 




F33A Motor: Unrecovered Predriver fault 




F33C Motor: Unrecovered Predriver Watchdog Fsys error 




F33E Motor: Unrecovered Predriver Watchdog DAC error 




F340 Motor: Unrecovered Predriver Speed Low error 




F342 Motor: Unrecovered Predriver UV Vboost error 




F344 Motor: Unrecovered Predriver NREG UV error 




F346 Motor: Unrecovered Predriver Ext NPOR error 




F348 Motor: Unrecovered Predriver Reg UV error 




F34A Motor: Unrecovered Predriver Under Voltage 12 Volt Supply error 




F34C Motor: Unrecovered Predriver Under Voltage 5 Volt Supply error 




F34E Motor: Unrecovered Predriver Over Voltage 12 Volt Supply error 




F350 Motor: Unrecovered Predriver Under Voltage 1.8 Volt Supply error 




F352 Motor: Unrecovered Predriver Under Voltage 0.9 Volt Supply error 




F354 Motor: Unrecovered Predriver Under Voltage 1.5 Volt Supply error 




F356 Motor: Unrecovered Predriver Shock Detected error 




F358 Motor: Unrecovered Predriver Over Temperature error 




F35A Motor: Unrecovered Predriver Under Voltage 3.3 Volt Supply error 




F35C Motor: Unrecovered Predriver Under Voltage 5 and 12 Volt Supply error 
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F35E Motor: Unrecovered Predriver Error in Enabling Power Saving Mode 




F360 Motor: Unrecovered Predriver Fault in Auto Retract 




F362 Motor: Unrecovered Predriver Error in Utilizing External Power Supply 




F364 Motor: Unrecovered Predriver Regulator Supply Fault 

4 

44 

F2 

Vendor Unique - Internal Target Failure 




FI 34 Head Health Check data compare error 

4 

44 

F6 

Vendor Unique - Internal Target Failure 




FI 35 Head Health Check unrecovered media error 




FI 41 BATS#2 error Read/Write Test Compare Failed 

4 

44 

F9 

Vendor Unique - Internal Target Failure 




F452 Servo: Unrecovered SHARP Parity Rate Error 




F456 Servo: Unrecovered SHARP Decode Rate Error 




F45A Servo: Unrecovered SHARP Timeout Rate Error 




F45E Servo: Unrecovered SHART Other Rate Error 

4 

44 

FA 

Vendor Unique - Internal Target Failure 




F450 Servo: Unrecovered SHARP Parity Error 




F454 Servo: Unrecovered SHARP Decode Error 




F458 Servo: Unrecovered SHARP Timeout Error 




F45C Servo: Unrecovered SHARP Other Error 

4 

81 

00 

Vendor Unique - Internal Logic Error 




F549 Host Interface: LA Check error 




F54D Host Interface: Super Certify Logic Error 




F56F Host Interface: Log dump data memory error 




F602 Channel/AE: Unrecovered Internal Logic Error 

4 

85 

00 

Vendor Unique - Internal Key Seed Error 




1768 Media: Recovered Key Seed ID Mismatch Error 




F769 Media: Unrecovered Key Seed ID Mismatch Error 

Sense Key = Illegal Request 

5 

15 

00 

PHY Test In Progress Error 




F50D Host Interface: PhyTest Function in Progress 

5 

1A 

00 

Parameter List Length Error 




F820 CMD: Unrecovered Parameter List Length Error 

5 

20 

00 

Invalid Command Operation Code 




F821 CMD: Unrecovered Invalid Opcode in CDB Error 

5 

21 

00 

Logical Block Address out of Range 




F822 CMD: Unrecovered LBAOut Of Range Error 

5 

24 

00 

Invalid Field in CDB 




F823 CMD: Unrecovered Invalid Field In CDB Error 

5 

25 

00 

Logical Unit Not Supported 




F824 CMD: Unrecovered Invalid LUN Error 

5 

26 

00 

Invalid Field in Parameter List 




F579 Host Interface: Data Checksum Error 




F825 CMD: Unrecovered Invalid Field In Parameter List Error 




F826 CMD: Unrecovered Unsupported Log Page Error 

5 

26 

02 

Parameter Value Invalid 




FI20 BATS error: Code Compatibility Failure 
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FI 26 BATS error: Code checksum error 




FI27 BATS error: Invalid header 




FI 30 BATS error: Incorrect Customer Code 




FI 3D BATS error: Invalid Code Signature 




F830 CMD: Unrecovered Sequence Error 

5 

26 

04 

Invalid Release of Active Persistent Reservation 




F828 CMD: Unrecovered Invalid Release of Persistent Reservation Error 

5 

2A 

03 

Reservation Conflict 




F536 Host Interface: Reservation conflict 

5 

2C 

00 

Illegal Request Sequence Error 




F511 Host Interface: Illegal Request Sequence Error 

5 

49 

00 

Invalid Message Error 




F512 Host Interface: Invalid Message 

5 

55 

04 

Insufficient Registration Resources 




F567 Host Interface: Insufficient registration resources 

Sense Key = Unit Attention 

5 

80 

01 

Unaligned write command 



02 

Write boundary violation 



03 

Attempt to read invalid data 



04 

Read boundary violation 

6 

28 

00 

Not Ready To Ready Transition (Format completed) 




F514 Host Interface: Not ready to ready transition 

6 

29 

01 

Unit Attention - POR Occurred 




F516 Host Interface: Power on reset 

6 

29 

02 

Unit Attention - SCSI Bus Reset Occurred 




F517 Host Interface: LIP reset (FC-AL), SAS Hard Reset (SAS) 

6 

29 

03 

Unit Attention - Bus Device Reset Occurred 




F518 Host Interface: Target Reset (FC-AL), LUN Reset (SAS) 

6 

29 

04 

Unit Attention - Self Initiated Reset Occurred 




F519 Host Interface: Self initiated reset 

6 

29 

07 

l_T Nexus Loss Occurred 




F554 Host Interface: l_T_Nexus Loss Occurred (SAS) 

6 

2A 

01 

Mode Parameters Changed 




F51C Host Interface: Mode parameters changed 

6 

2A 

02 

Log Parameters Changed 




F51D Host Interface: Log parameters changed 

6 

2A 

03 

Reservations Preempted 




F51E Host Interface: Reservations pre-empted 

6 

2A 

04 

Reservations Released 




F51F Host Interface: Reservations released 

6 

2A 

05 

Registrations Released 




F520 Host Interface: Registrations pre-empted 

6 

2A 

09 

Capacity Data Changed 




F524 Host Interface: Capacity Data Changed 

6 

2F 

00 

Commands Cleared by Another Initiator 




F521 Host Interface: Commands cleared by another initiator 

6 

2F 

01 

Commands Cleared by Power Loss Notification 
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F573 Host Interface: Commands cleared due to power failure event (SAS) 

6 

3F 

01 

Microcode has been changed 




F522 Host Interface: Microcode changed 

6 

3F 

05 

Device Identifier Changed 




F537 Host Interface: Device identifier changed 

Sense Key = Access Denied 

7 

20 

02 

Access Denied 




F509 Host Interface: In Self-Test - Band locked 




F827 CMD: Unrecovered Access Denied Error 

Sense Key = Aborted Command 

B 

0E 

02 

Information Unit Too Long 




F562 Host Interface: Information unit too long (SAS) 

B 

10 

01 

Aborted Command - End-to-End Guard Check 




F568 Host Interface: End-to-End Data Protection Guard check 




F7BD Media: Unrecovered Guard Check Error 

B 

10 

02 

Aborted Command - End-to-End Application Tag Check 




F569 Host Interface: End-to-End Data Protection Application Tag check 




F7BB Media: Unrecovered Application Tag Error 

B 

10 

03 

Aborted Command - End-to-End Reference Tag Check 




F56A Host Interface: End-to-End Data Protection Reference Tag check 




F7B9 Media: Unrecovered Reference Tag error 

B 

3F 

OF 

Aborted Command - Echo Buffer Overwritten 




F544 Host Interface: Echo buffer overwritten 

B 

44 

00 

Internal Target Failure 




F52D Host Interface: Buffer CRC error on read 




F52E Host Interface: Internal target failure 




F54A Host Interface: Xfer Ready credit exceeded 




F54B Host Interface: Transfer length error 




F56B Host Interface: ECC error in DRAM customer data area 




F56C Host Interface: Uncorrectable DRAM ECC error 




F570 Host Interface: Host interface Synchronous CRC error 




F57A Host Interface: Synchronous CRC Error on Write 




F57B Host Interface: Synchronous CRC LBA Error 




F608 Channel/AE: Unrecovered Invalid SAT Sector Length Error 




F62F Channel: Unrecovered Channel NRZ Clear Timeout Error 




F741 Media: OCT Timeout Not Dispatched 




F742 Media: OCT Timeout In Recovery 




F743 Media: OCT Timeout Executing 




F75C Media: Unrecovered Internal Media Access Timeout Error 




F772 Media: Unrecovered DASH starting timeout 




F773 Media: Unrecovered ID table timeout 




F774 Media: Unrecovered Servo timeout 




F775 Media: Unrecovered Buffers timeout 




F776 Media: Unrecovered DASH done timeout 




F777 Media: Unrecovered DASH unknown timeout 




F77B Media: Unrecovered Abort EOS fail 
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F77E Media: Write Error Recovery Timeout 




F77F Media: Read Error Recovery Timeout 




F7D0 Media: Unrecovered Pre-load Timeout Error 




F813 CMD: Insufficient Buffer Space Error 

B 

47 

01 

Data Phase CRC Error 




F54E Host Interface: Data Phase CRC Error 

B 

4B 

00 

Data Phase Error 




F53E Host Interface: Data phase error 

B 

4B 

02 

Too Much Write Data 




F560 Host Interface: Too much write data (SAS) 

B 

4B 

03 

ACK/NAK Timeout 




F551 Host Interface: ACK NAK Timeout (SAS) 




F57D Host Interface: Break Received (SAS only) 

B 

4B 

04 

NAK Received 




F550 Host Interface: NAK rcvd (SAS) 

B 

4B 

05 

Data Offset Error 




F552 Host Interface: Bad parameter offset (SAS) 

B 

4B 

06 

Initiator Response Timeout 




F555 Host Interface: Initiator Response Timeout (SAS) 

B 

4E 

00 

Overlapped Commands Attempted 




F534 Host Interface: Overlapped command attempted 

B 

4F 

00 

Command Aborted Due To Loop Initialization 




F53F Host Interface: Abort by OOB (SAS) 

Sense Key = Miscompare 

E 

ID 

00 

Miscompare During Verify Operation 




F535 Host Interface: Miscompare during verify 
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15.2.9 FRU: Field Replaceable Unit (Byte 14) 

The FRU (Field Replaceable Unit) field value will always be zero. 

Note: The FRU field may be used to store vendor specific information in certain firmware builds. 

15.2.10 Sense Key Specific (Byte 15 through 17) 

The definition of this field is determined by the value of the sense key field. 

15.2.10.1 Sense Key Specific - Illegal Request (Sense Key = 5h) 


Error field pointer is returned. 
Table 334 Field Pointer Bytes 


Byte 

Bit 

7 

6 

5 | 4 

3 

2 | 1 | o 

15 

SKSV 

C/D 

Reserved 

BPV 

Bit Pointer 

16-17 

(MSB) 

Field Pointer 

(LSB) 


SKSV 

C/D 


BPV 


Bit Pointer 
Field Pointer 


Sense-key specific valid 
0 Sense-key specific field is not valid. 

1 Sense-key specific field is valid. 

Command/Data 

0 Indicates that the illegal parameter was in the data parameters sent by the initiator during 
DATA OUT phase 

1 Indicates that the illegal parameter was in the command descriptor block. 

Bit Pointer Valid 

0 Bit pointer field is not valid. 

1 Bit pointer field is significant. 

Indicates which bit of the byte number reported in Field Pointer is the bit in error. When a multiple 
bit field is in error, the pointer points to the most significant bit of the field. 

Indicates which bytes of the command descriptor block or of the parameter data were in error. 
Bytes are numbered starting from zero, as shown in the tables describing the commands and 
parameters. When a multiple byte field id is in error, the pointer points to the most significant byte 
of that field. 
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15.2.10.2 Sense Key Specific -Recovered (Sense Key = lh) or Medium (Sense 
Key = 3h) or Hardware (Sense Key = 4h) 


Hardware (Sense Key = 4h) or Medium Error (Sense Key = 3h) 
Actual Retry Count is reported. 

Table 335 Actual Retry Count 


Byte 

Bit 

7 

6 5 

4 3 2 1 


15 

SKSV 

Reserved 

16 


Secondary Step 

! ERP Type 


17 

Actual Retry Count 


SKSV 


Actual Retry Count 
Secondary Step 
ERP Type 


Sense-key specific valid 
0 Actual Retry Count is not valid. 

1 Actual Retry Count is valid. 

Number of retry steps used in attempting to recover from the error condition. 
Secondary error recovery step (valid for servo errors only). 

Error recovery table branch for this error. Valid values are shown in the table below. 


Table 336 Recovery Type 


Recovery Type 

ERP Type 

Read 

0x00 

Verify 

0x01 

Write 

0x02 

Seek 

0x03 

Read, Sync Byte branch 

0x04 

Read, Thermal Asperity branch 

0x05 

Read, Minus Mod branch 

0x06 

Verify, Sync Byte branch 

0x07 

Verify, Thermal Asperity branch 

0x08 

Verify, Minus Mod branch 

0x09 
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15.2.10.3 Not Ready (Sense key = 2h) 

These fields are defined for the Format unit (04h) command with the immediate bit set to one and the Send Diagnostic 
(1 Dh) command with Background self-test function. 

Progress indication is returned. 

Table 337 Progress Indication 


Byte 

Bit 

7 

6 5 4 3 21 0 

15 

SKSV 

Reserved 

16-17 

(MSB) 

Progress Indication 

(LSB) 


SKSV Sense-key specific valid 

0 Progress Indication is not valid. 

1 Progress Indication is valid. 

Progress Indication Indicates a percent complete in which the returned value is the numerator that has 
lOOOOh as its denominator. 

15.2.11 Reserved (Byte 18 through 19) 

Reserved fields are filled with zero. 

15.2.12 Vendor unique error information (Byte 20 through 23) 

This field gives detailed information about the error. It contains a unique code which describes where the error was 
detected and which piece of hardware or microcode detected the error depending on current operation. 

15.2.13 Physical Error Record (Product Specific Information) (Byte 24 thru 
29) 

• ILI = 1 - This field contains zeros. 

• ILI = 0 - These bytes contain the physical location of the error in cylinder, head, and sector. Bytes 24, 25, and 
26 are cylinder high, middle and low bytes respectively, of the cylinder number. Byte 27 is the head number. 
Bytes 28 and 29 are the high and low bytes, respectively of the sector number. 

If the head is undetermined, bytes 24, 25, and 26 are set to OFFFFFFh. If the head number is undetermined, byte 27 
is set to OFFh. If cylinder, head, and sector have no relevance the error, bytes 24 through 29 will all be set to 
OFFFFFFFFFFFFh for Valid = 0 and ILI = 0. This Physical Error Record field is valid for Sense Key 1,3, and 4 only. 


Table 338 Log Only Errors 


Valid 

ILI 

Description 

1 

0 

Cylinder Number (bytes 24-26) 

Head number (byte 27) 

Sector Number (bytes 28-29) 

1 

1 

0x000000000000 

0 

X 

0x000000000000 - (not used/invalid) 
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15.3 Descriptor Format Sense Data 

The descriptor format sense data for response codes 72h (current errors) and 73h (deferred errors) is defined below. 
Table 339 Descriptor Format Sense Data 


Byte 

Bit I 

7 

6 5 4 3 21 0 

0 

Reserved=0 

Response Code (72h or 73h) 

1 

Reserved Sense Key 

2 

Additional Sense Code 

3 

Additional Sense Code Qualifier 

4-6 

Reserved 

7 

Additional Sense Length (n-7) 

8-m 

Sense Data Descriptor # 1 

m...x 


x -n 

Sense Data Descriptor # K 


Response Code: 72h Current Error. See section 15.1.3 "Sense Data Response Code" for more details. 

73h Deferred Error. See section 15.1.3 "Sense Data Response Code" for more details. 

The Sense Key definitions is the same as fixed format sense data. 

The Additional Sense Code/Qualifier definitions is the same as fixed format sense data. 

The Value of the Additional Sense Length indicates the remaining number of bytes in the sense data 

Sense data descriptors (Byte 8 through n) provide specific sense information. The general format of a sense data 

descriptor is shown below: 

Table 340 Sense Data Descriptor Format 


Byte 

Bit 

7 6 5 4 3 21 0 

0 

Descriptor Type 

1 

Additional Length (n-1) 

2-n 

Sense Data Descriptor Specific 


The Descriptor Type identifies the type of a sense data descriptor. (Supported types are listed below) 
Table 341 Supported Descriptor Types 


Type Code 

Description 

OOh 

Information Sense Data Descriptor 

01 h 

Command-specific Sense Data Descriptor 

02 h 

Sense Key Specific Sense Data Descriptor 

03 h 

Field Replaceable Unit Sense Descriptor 

05 h 

Block Command Sense Data Descriptor 

80h 

Vendor Unique Unit Error Code Sense Data Descriptor 


The ADDITIONAL LENGTH field indicates the number of sense data descriptor specific bytes that follow in the sense 
data descriptor. 
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15.3.1 Order of Sense Descriptors 

The drive may return up to 7 sense data descriptors in byte 8 through byte 59 of the sense data, up to the number of 
sense data bytes allowed (see Table 342). The sense descriptors returned will always be in the order shown in the 
table below, regardless of whether a descriptor contains valid information or not. 

Table 342 Sense Data Descriptor List 


Byte 

Bit 

7 1 6 1 5 | 4 | 3 | 2 | 1 | 0 

0-7 

Common Headers 

8-19 

Information Sense Data Descriptor 

20-31 

Command-specific Sense Data Descriptor 

32-39 

Sense Key Specific Sense Data Descriptor 

40-43 

Field Replaceable Unit (FRU) Sense Data Descriptor 

44-47 

Block Command Sense Data Descriptor 

48-51 

Vendor Unique Unit Error Code Sense Data Descriptor 

51-59 

Vendor Unique Physical Error Record Sense Data Descriptor 


15.3.2 Sense Data Descriptor Definitions 

15.3.2.1 Information Sense Data Descriptor (Byte 8 -19) 

The Information Sense Data Descriptor is stored in bytes 8 through 19 of the descriptor format sense data. Format of 
the Information Sense Data Descriptor is shown in Table 343 

Table 343 Information Sense Data Descriptor Format 


Byte 

Bit 

7 6 5 4 3 210 

0 

Descriptor Type (OOh) 

1 

Additional Length (OAh) 

2 

VALID Reserved 

3 

Reserved 

4-11 

Information 


Descriptor Type Set to OOh for Information Sense Data Descriptor. 

Additional Length Set to OAh for Information Sense Data Descriptor. 


VALID This bit is set to 1 when content of the Information field is valid, and set to 0 if the Information 

field is invalid. 

Information This field contains an LBA or other information depending on the value of the ILI bit in the 

Block Command Sense Descriptor (See section 15.3.2.5 "Block Command Sense 
Descriptor (Byte 44 - 47)"). 


- ILI = 0 (or if the descriptor is not present): The Information field contains the unsigned LBA associated with the 
sense key. The LBA reported will be within the LBA range of the command as defined in the CDB. 

Note: An LBA other than the command LBA may be reported on the Reassign Block (07h) command. 

- ILI = 1: The Information field contains the difference (residue) of the requested length in bytes. Negative values 
are indicated by two's complement notation 
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15.3.2.2 Command-specific Sense Data Descriptor (Byte 20 - 31) 

The Command-specific Sense Data Descriptor is stored in bytes 20 through 31 of the descriptor format sense data. 
Format of the format of Command-specific Sense Data Descriptor is shown in Table 344. 

Table 344 Command-specific Sense Data Descriptor Format 


Byte 

Bit 

7 1 6 | 5 | 4 | 3 | 2 | 1 | 0 

0 

Descriptor Type (01 h) 

1 

Additional Length (OAh) 

2 

Reserved 

3 

Reserved 

4-11 

Command-Specific Information 


Descriptor Type Set to 01 h for Command-specific Sense Data Descriptor. 


Additional Length Set to OAh for Command-specific Sense Data Descriptor. 


Command-specific The value of this field is set the same ways as Command Specific Information field in fixed 
Information format sense data (See section 15.2.7 "Command Specific Information (Byte 8 through 

11 )") 


15.3.2.3 Sense Key Specific Sense Data Descriptor (Byte 32 - 39) 

The Sense-key Specific Sense Data Descriptor is stored in bytes 32 through 39 of the descriptor format sense data. 
Format of Sense-key Specific Sense Data Descriptor is shown in Table 345. 

Table 345 Information Sense Data Descriptor Format 


Byte 

Bit 

7 6 5 4 3 210 

0 

Descriptor Type (02h) 

1 

Additional Length (06h) 

2 

Reserved 

3 

Reserved 

4 

SKSV Sense Key Specific Bits 

5-6 

Sense Key Specific Bytes 

7 

Reserved 


Descriptor Type Set to 02h for Command-specific Sense Data Descriptor. 

Additional Length Set to 06h for Command-specific Sense Data Descriptor. 

Fields in byte 4 through 5 (including the SKSV bit, Sense-Key Specific Bits, and Sense-Key Specific Bytes): 

These fields are set the same ways as byte 15 - 17 in fixed format sense data (See section 15.2.10 "Sense Key 
Specific (Byte 15 through 17)" for details). 
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15.3.2.4 Field Replaceable Unit (FRU) Sense Data Descriptor (Byte 40 - 43) 

The Field Replaceable Unit (FRU) Sense Data Descriptor is stored in bytes 40 through 43 of descriptor format sense 
data. Format of Field Replaceable Unit (FRU) Sense Data Descriptor is shown in Table 346. 

Table 346 Field Replaceable Unit Sense Data Descriptor Format 


Byte 

Bit 

7 6 5 4 3 210 

0 

Descriptor Type (03h) 

1 

Additional Length (02h) 

2 

Reserved 

3 

Field Replaceable Unit Code 


Descriptor Type 
Additional Length 

Command-specific 

Information 


Set to 03h for Command-specific Sense Data Descriptor. 

Set to 02h for Field Replaceable Unit Sense Data Descriptor. 

This field is set the same way as the Field Replaceable Unit Code of fixed format sense 
data. (See section 15.2.9 "FRU: Field Replaceable Unit (Byte 14) 

FRU: Field Replaceable Unit (Byte 14)" for details). 


15.3.2.5 Block Command Sense Descriptor (Byte 44 - 47) 

The Block Command Sense Data Descriptor is stored in bytes 44 through 47 of descriptor format sense data. Format 
of the Block Command Sense Data Descriptor is shown in Table 347. 

Table 347 Block Command Sense Data Descriptor Format 


Byte 

Bit 

7 6 5 4 3 21 0 

0 

Descriptor Type (05h) 

1 

Additional Length (02h) 

2 

Reserved 

3 

Reserved=0 ILI Reserved=0 


Descriptor Type Set to 05h for Block Command Sense Data Descriptor. 
Additional Length Set to 02h for Block Command Sense Data Descriptor. 


ILI: Value of the ILI bit is set to indicate what type of value is stored in the Information field of the 

Information Sense Data Descriptor (see section 15.3.2.1 "Information Sense Data Descriptor 
(Byte 8 -19)" for details): 
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15.3.2.6 Vendor Unique Unit Error Sense Data Descriptor (Byte 48 - 51) 

The Vendor Unique Unit Error Code Sense Data Descriptor is stored in bytes 48 through 51 of descriptor format 
sense data. Format of the Vendor Unique Unit Error Code Sense Data Descriptor is shown in Table 348. 

Table 348 Vendor Unique Unit Error Code Sense Data Descriptor 


Byte 

Bit 

7 6 5 4 3 21 0 

0 

Descriptor Type (80h) 

1 

Additional Length (02h) 

2-3 

Unit Error Code (UEC) 


Descriptor Type Set to 80h for Vendor Unique Unit Error Code Sense Data Descriptor. 

Additional Length Set to 02h for Vendor Unique Unit Error Code Sense Data Descriptor. 

Unit Error Code: This field contains the same value as the Vendor Unique Error Information field in fixed format 

sense data which gives detailed information about the error (See section 15.2.12 "Vendor 
unique error information (Byte 20 through 23)"). It contains a unique code which describes 
where the error was detected and which piece of hardware or microcode detected the error 
depending on current operation 


15.3.2.7 Vendor Unique Physical Error Record Sense Data Descriptor (Byte 
52-59) 

The Vendor Unique Physical Error Record Sense Data Descriptor is stored in bytes 52 through 59 of descriptor format 
sense data. Format of the Vendor Unique Physical Error Record Sense Data Descriptor is shown in Table 348. 

Table 349 Vendor Unique Physical Error Record Sense Data Descriptor 


Byte 

Bit 

7 H 6 1 5 1 4 I”” 3 | 2 | 1 | 0 

0 

Descriptor Type (81 h) 

1 

Additional Length (06h) 

2-7 

Physical Error Record 


Descriptor Type 
Additional Length 
Unit Error Code: 


Set to 81 h for Vendor Unique Unit Physical Error Record Sense Data Descriptor. 

Set to 06h for Vendor Unique Unit Physical Error Record Sense Data Descriptor. 

This field is set the same way as the Physical Error Record in fixed format sense data. (See 
section 15.2.13 "Physical Error Record (Product Specific Information) (Byte 24 thru 29)" for 
details). 
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16 Appendix. UEC list 

Following is the list of Unit Error Codes and associated descriptions. The Unit Error Codes are returned by the target 
in sense data bytes 20-21. 

The list of Unit Error Codes and descriptions does not have a direct correlation to the error descriptions and Sense 
Key/Code/Qualifier descriptions in Section 10 "Additional information". These codes are used internally by FIGST and 
may change without notice. 

How to find a specific UEC 

The second hex digit indicates the grouping, e.g. interface, media, servo, etc. types of errors. The table is sorted 
without regard to the first hex digit; instead, sorting is by the least significant three hex digits. 

Table 350 Unit Error Codes 


UEC 

Description 

0000 

No Error 



FI 01 

BATS error: Reserved Area - Invalid request 

FI 02 

BATS error: Reserved Area - Broken 

FI 03 

BATS error: Reserved Area - Invalid version 

FI 04 

BATS error: Reserved Area - Invalid checksum 

FI 05 

BATS error: Reserved Area - Invalid eye catcher 

FI 06 

BATS error: Reserved Area - Invalid main header checksum 

FI 07 

BATS error: Reserved Area - Invalid read length 

FI 08 

BATS error: Reserved Area - Address boundary error 

FI 0D 

BATS error: Reserved Area - Write fix hard error 

FI 0E 

BATS error: Directory broken 

Fill 

BATS error: RAM code load error 

F112 

BATS error: RAM code check 

F118 

BATS#2 error: Seek test error 

F119 

BATS#2 error: Read/write test error 

F11B 

BATS#2 error: CRC test error 

F11C 

BATS#2 error: XOR test error 

F11D 

BATS error: Incorrect Disk Code 

FI 20 

BATS error: Code Compatibility Failure 

FI 24 

Bring-up error 

FI 25 

BATS error: Invalid RID/FID 

FI 26 

BATS error: Code checksum error 

FI 27 

BATS error: Invalid header 

F12A 

DRAM test error 

F12B 

BATS error: Reserved area - invalid model 

F12C 

BATS error: Invalid code size 

F12D 

Format Reserved: FAT Size Exceeded Error 

F12E 

Format Reserved: Insufficient DIRS Good Error 

F12F 

Format Reserved: Insufficient FATS Good Error 

FI 30 

BATS error: Incorrect Customer Code 
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F131 

Flash timeout 

FI 32 

GEM FH track read error 

FI 33 

BATS error: Vendor ID mismatch 

FI 34 

Head Health Check data compare error 

FI 35 

Head Health Check unrecovered media error 

FI 36 

BATS#2 error: End-To-End Data Protection error 

FI 37 

Flash ECC error 

FI 38 

BATS error: ATI RID Error 

FI 39 

Format Reserved: Resize RID/FID Error 

F13A 

BATS error: RSEC Read Error 

F13B 

BATS error: SW Target broken 

F13C 

BATS error: NCDE DRAM failure 

F13D 

BATS error: Invalid Code Signature 

F13E 

BATS#2 error: TCG Test Failed 

F13F 

BATS#2 error: Read/Write Test Compare Failed 

FI 40 

Format Reserved: Too many Defects Error 

FI 41 

BATS#2 error Read/Write Test Compare Failed 



1201 

Sanity: Error In UEC Class 

1202 

Sanity: Error In UEC Cause 

F203 

Sanity: Sanity Check Failure 

F204 

Reassign reserved area media error 

F205 

G-list full - can't reassign any more sectors 

F206 

No spares available 

F208 

Mode Page Structure Mismatch 

F209 

Miscompare of SBA in the P-List 

F20A 

Error Clearing Reset State 



1301 

Motor: Recovered internal error 

F302 

Motor: Unrecovered internal error 

1303 

Motor: Recovered Open Loop Commutation failure 

F304 

Motor: Unrecovered Open Loop Commutation failure 

1305 

Motor: Recovered No feedback detected error 

F306 

Motor: Unrecovered No feedback detected error 

1307 

Motor: Recovered Settle timeout 

F308 

Motor: Unrecovered Settle timeout 

1309 

Motor: Recovered Gross speed error 

F30A 

Motor: Unrecovered Gross speed error 

130B 

Motor: Recovered 12V OK error 

F30C 

Motor: Unrecovered 12V OK error 

130D 

Motor: Recovered Speed error 

F30E 

Motor: Unrecovered Speed error 

130F 

Motor: Recovered Spindle Current error 
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F310 

Motor; 

Unrecovered Spindle Current error 

1311 

Motor 

Recovered Internal 12V not OK timeout 

F312 

Motor 

Unrecovered Internal 12V not OK timeout 

1313 

Motor; 

Recovered Inductive Sense measurement timeout 

F314 

Motor 

Unrecovered Inductive Sense speed error 

1315 

Motor 

Recovered Spin Sense speed error 

F316 

Motor; 

Unrecovered Spin Sense speed error 

1317 

Motor 

Recovered Spin Sense timeout 

F318 

Motor 

Unrecovered Spin Sense timeout 

1319 

Motor; 

Recovered Target speed error 

F31A 

Motor 

Unrecovered Target speed error 

F31B 

Motor 

Unrecovered Power driver version error 

F31C 

Motor 

Unrecovered Power driver version error 

131D 

Motor 

Recovered Over current error 

F31E 

Motor 

Unrecovered Over current error 

131F 

Motor; 

Recovered System clock watchdog error 

F320 

Motor 

Unrecovered System clock watchdog error 

1321 

Motor 

Recovered Negative regulator fault 

F322 

Motor; 

Unrecovered Negative regulator fault 

1323 

Motor 

Recovered Module overtemp error 

F324 

Motor 

Unrecovered Module overtemp error 

1325 

Motor 

Recovered 12V or 5V OK error 

F326 

Motor 

Unrecovered 12V or 5V OK error 

1327 

Motor 

Recovered unknown error 

F328 

Motor; 

Unrecovered unknown error 

1329 

Motor 

Recovered VCM DAC watchdog error 

F32A 

Motor 

Unrecovered VCM DAC watchdog error 

132B 

Motor; 

Recovered Module mid-die overtemp fault 

F32C 

Motor 

Unrecovered Module mid-die overtemp fault 

132D 

Motor 

Recovered Module Vcmp hi-side overtemp fault 

F32E 

Motor; 

Unrecovered Module Vcmp hi-side overtemp fault 

132F 

Motor 

Recovered Module Vcmn hi-side overtemp fault 

F330 

Motor 

Recovered Module Vcmn hi-side overtemp fault 

1331 

Motor; 

Recovered Invalid standby RPM request 

F332 

Motor 

Unrecovered Invalid standby RPM request 

1333 

Motor 

Recovered Invalid spin state request 

F334 

Motor; 

Unrecovered Invalid spin state request 

1335 

Motor 

Recovered Hardware retract timeout 

F336 

Motor 

Unrecovered Hardware retract timeout 

1337 

Motor; 

Recovered thermal limit exceeded 

F338 

Motor 

Unrecovered thermal limit exceeded 

1339 

Motor 

Recovered Predriver fault 

F33A 

Motor; 

Unrecovered Predriver fault 
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133B 

Motor; 

Recovered Predriver Watchdog Fsys error 

F33C 

Motor 

Unrecovered Predriver Watchdog Fsys error 

133D 

Motor 

Recovered Predriver Watchdog DAC error 

F33E 

Motor; 

Unrecovered Predriver Watchdog DAC error 

133F 

Motor 

Recovered Predriver Speed Low error 

F340 

Motor 

Unrecovered Predriver Speed Low error 

1341 

Motor 

Recovered Predriver UV Vboost error 

F342 

Motor 

Unrecovered Predriver UV Vboost error 

1343 

Motor 

Recovered Predriver NREG UV error 

F344 

Motor; 

Unrecovered Predriver NREG UV error 

1345 

Motor 

Recovered Predriver Ext NPOR error 

F346 

Motor 

Unrecovered Predriver Ext NPOR error 

1347 

Motor 

Recovered Predriver Reg UV error 

F348 

Motor 

Unrecovered Predriver Reg UV error 

1349 

Motor 

Recovered Predriver Under Voltage 12 Volt Supply error 

F34A 

Motor; 

Unrecovered Predriver Under Voltage 12 Volt Supply error 

134B 

Motor 

Recovered Predriver Under Voltage 5 Volt Supply error 

F34C 

Motor 

Unrecovered Predriver Under Voltage 5 Volt Supply error 

134D 

Motor 

Recovered Predriver Over Voltage 12 Volt Supply error 

F34E 

Motor 

Unrecovered Predriver Over Voltage 12 Volt Supply error 

134F 

Motor 

Recovered Predriver Under Voltage 1.8 Volt Supply error 

F350 

Motor; 

Unrecovered Predriver Under Voltage 1.8 Volt Supply error 

1351 

Motor 

Recovered Predriver Under Voltage 0.9 Volt Supply error 

F352 

Motor 

Unrecovered Predriver Under Voltage 0.9 Volt Supply error 

1353 

Motor 

Recovered Predriver Under Voltage 1.5 Volt Supply error 

F354 

Motor 

Unrecovered Predriver Under Voltage 1.5 Volt Supply error 

1355 

Motor 

Recovered Predriver Shock Detected error 

F356 

Motor; 

Unrecovered Predriver Shock Detected error 

1357 

Motor 

Recovered Predriver Over Temperature error 

F358 

Motor 

Unrecovered Predriver Over Temperature error 

1359 

Motor; 

Recovered Predriver Under Voltage 3.3 Volt Supply error 

F35A 

Motor 

Unrecovered Predriver Under Voltage 3.3 Volt Supply error 

135B 

Motor 

Recovered Predriver Under Voltage 5 and 12 Volt Supply error 

F35C 

Motor; 

Unrecovered Predriver Under Voltage 5 and 12 Volt Supply error 

135D 

Motor 

Recovered Predriver Error in Enabling Power Saving Mode 

F35E 

Motor 

Unrecovered Predriver Error in Enabling Power Saving Mode 

135F 

Motor 

Recovered Predriver Fault in Auto Retract 

F360 

Motor 

Unrecovered Predriver Fault in Auto Retract 

1361 

Motor 

Recovered Predriver Error in Utilizing External Power Supply 

F362 

Motor; 

Unrecovered Predriver Error in Utilizing External Power Supply 

1363 

Motor 

Recovered Predriver Regulator Supply Fault 

F364 

Motor 

Unrecovered Predriver Regulator Supply Fault 

1365 

Motor 

Recovered Predriver Voltage Offset Calibration Error 
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F366 

Motor: Unrecovered Predriver Voltage Offset Calibration Error 

1367 

Motor: Recovered Predriver BEMF Gain Calibration Error 

F368 

Motor: Unrecovered Predriver BEMF Gain Calibration Error 

1369 

Motor: Recovered Predriver BEMF Unload Calibration Error 

F36A 

Motor: Unrecovered Predriver BEMF Unload Calibration Error 



1401 

Servo: Recovered Requested rezero head does not exist 

F402 

Servo: Unrecovered Requested rezero head does not exist 

1403 

Servo: Recovered Back EMF movement in progress 

F404 

Servo: Unrecovered Back EMF movement in progress 

1405 

Servo: Recovered Back EMF timeout error 

F406 

Servo: Unrecovered Back EMF timeout error 

1407 

Servo: Recovered ADC conversion timeout 

F408 

Servo: Unrecovered ADC conversion timeout 

1409 

Servo: Recovered Load/unload calibration error 

F40A 

Servo: Unrecovered Load/unload calibration error 

140B 

Servo: Recovered Invalid 5 volts 

F40C 

Servo: Unrecovered Invalid 5 volts 

HOD 

Servo: Recovered Invalid 12 volts 

F40E 

Servo: Unrecovered Invalid 12 volts 

HOF 

Servo: Recovered Invalid harmonic requested 

F410 

Servo: Unrecovered Invalid harmonic requested 

1411 

Servo: Recovered Gain BEMF Calibration error 

F412 

Servo: Unrecovered Gain BEMF Calibration error 

1413 

Servo: Recovered VOFF BEMF calibration error 

F414 

Servo: Unrecovered VOFF BEMF calibration error 

1415 

Servo: Recovered Invalid temperature 

F416 

Servo: Unrecovered Invalid temperature 

1417 

Servo: Recovered Truncated rezero 

F418 

Servo: Unrecovered Truncated rezero 

1419 

Servo: Recovered Heads not loaded 

F41A 

Servo: Unrecovered Heads not loaded 

141 B 

Servo: Recovered Current error 

F41C 

Servo: Unrecovered Current error 

141 D 

Servo: Recovered Seek timeout 

F41E 

Servo: Unrecovered Seek timeout 

141 F 

Servo: Recovered Seek error 

F420 

Servo: Unrecovered Seek error 

1421 

Servo: Recovered Track following error 

F422 

Servo: Unrecovered Track following error 

1423 

Servo: Recovered Track follow timeout 

F424 

Servo: Unrecovered Track follow timeout 

1425 

Servo: Recovered KT Seek out of range 
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F426 

Servo 

Unrecovered KT Seek out of range 

1427 

Servo 

Recovered DAC Offset calibration error 

F428 

Servo 

Unrecovered DAC Offset calibration error 

1429 

Servo 

Recovered Load speed error 

F42A 

Servo 

Unrecovered Load speed error 

142B 

Servo 

Recovered RRO Calibration timeout 

F42C 

Servo 

Unrecovered RRO Calibration timeout 

142D 

Servo 

Recovered ADC Calibration error 

F42E 

Servo 

Unrecovered ADC Calibration error 

142F 

Servo 

Recovered ADC Offset error 

F430 

Servo 

Unrecovered ADC Offset error 

1431 

Servo 

Recovered ADC Limit error 

F432 

Servo 

Unrecovered ADC Limit error 

1433 

Servo 

Recovered Balancer Resistance error 

F434 

Servo 

Unrecovered Balancer Resistance error 

1435 

Servo 

Recovered Balancer Resistance Limit error 

F436 

Servo 

Unrecovered Balancer Resistance Limit error 

1437 

Servo 

Recovered First Cylinder error 

F438 

Servo 

Unrecovered First Cylinder error 

1439 

Servo 

Recovered Valid Cylinder error 

F43A 

Servo 

Unrecovered Valid Cylinder error 

143B 

Servo 

Recovered ADC Saturation error 

F43C 

Servo 

Unrecovered ADC Saturation error 

143D 

Servo 

Recovered Latch Break timeout 

F43E 

Servo 

Unrecovered Latch Break timeout 

143F 

Servo 

Recovered MR Resistance out of range error 

F440 

Servo 

Unrecovered MR Resistance out of range error 

1441 

Servo 

Recovered VCM Retract error 

F442 

Servo 

Unrecovered VCM Retract error 

1443 

Servo 

Recovered Load Retry error 

F444 

Servo 

Unrecovered Load Retry error 

1445 

Servo 

Recovered DFT Sharp error 

F446 

Servo 

Unrecovered DFT Sharp error 

1447 

Servo 

Recovered Load/Unload state error 

F448 

Servo 

Unrecovered Load/Unload state error 

1449 

Servo 

Recovered TFCR out-of-range error 

F44A 

Servo 

Unrecovered TFCR out-of-range error 

144B 

Servo 

Recovered Measure GMR Timeout 

F44C 

Servo 

Unrecovered Measure GMR Timeout 

144D 

Servo 

Recovered Coil Resistance Measurement Failure 

F44E 

Servo 

Unrecovered Coil Resistance Measurement Failure 

144F 

Servo 

Recovered SHARP Parity Error 

F450 

Servo 

Unrecovered SHARP Parity Error 
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1451 

Servo 

Recovered SHARP Parity Rate Error 

F452 

Servo 

Unrecovered SHARP Parity Rate Error 

1453 

Servo 

Recovered SHARP Decode Error 

F454 

Servo 

Unrecovered SHARP Decode Error 

1455 

Servo 

Recovered SHARP Decode Rate Error 

F456 

Servo 

Unrecovered SHARP Decode Rate Error 

1457 

Servo 

Recovered SHARP Timeout Error 

F458 

Servo 

Unrecovered SHARP Timeout Error 

1459 

Servo 

Recovered SHARP Timeout Rate Error 

F45A 

Servo 

Unrecovered SHARP Timeout Rate Error 

145B 

Servo 

Recovered SHARP Other Error 

F45C 

Servo 

Unrecovered SHARP Other Error 

145D 

Servo 

Recovered SHARP Other Rate Error 

F45E 

Servo 

Unrecovered SHART Other Rate Error 

145F 

Servo 

Recovered WCS Hang Error 

F460 

Servo 

Unrecovered WCS Hang Error 

1461 

Servo 

Recovered DFT Timeout Error 

F462 

Servo 

Unrecovered DFT Timeout Error 

1463 

Servo 

Recovered SDM Timeout Error 

F464 

Servo 

Unrecovered SDM Timeout Error 

1465 

Servo 

Recovered RRO Write Error 

F466 

Servo 

Unrecovered RRO Write Error 

1467 

Servo 

Recovered Velocity Error 

F468 

Servo 

Unrecovered Velocity Error 

1469 

Servo 

Recovered Start SID Incorrect Error 

F46A 

Servo 

Unrecovered Start SID Incorrect Error 

146B 

Servo 

Recovered End Sid Incorrect Error 

F46C 

Servo 

Unrecovered End Sid Incorrect Error 

146D 

Servo 

Recovered Measure GMR SDM Failure 

F46E 

Servo 

Unrecovered Measure GMR SDM Failure 

146F 

Servo 

Recovered VCM Free Speed Error 

F470 

Servo 

Unrecovered VCM Free Speed Error 

1471 

Servo 

Recovered Emergency Brake Timeout Error 

F472 

Servo 

Unrecovered Emergency Brake Timeout Error 

1473 

Servo 

Recovered Excessive Current Error 

F474 

Servo 

Unrecovered Excessive Current Error 

1475 

Servo 

Recovered Excessive Velocity Error 

F476 

Servo 

Unrecovered Excessive Velocity Error 

F477 

Servo 

Unrecovered Invalid SDM CDB Error 

F478 

Servo 

Unrecovered Invalid SDM Descriptor Error 

F479 

Servo 

Unrecovered Invalid DFT Descriptor Error 

F47A 

Servo 

Unrecovered SDM or DFT Allocation Error 

F47B 

Servo 

Unrecovered SDM OR DFT Transfer Error 
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F47C 

Servo: Unrecovered SDM Physical Parameter Error 

147D 

Servo: Recovered RROF SDM Timeout Error 

F47E 

Servo: Unrecovered RROF SDM Timeout Error 

147F 

Servo: Recovered RROF Over Limit Error 

F480 

Servo: Unrecovered RROF Over Limit Error 

F481 

Servo: Unrecovered Self-Test Failed 

1482 

Servo: Recovered Measure Asymmetry SDM Failure 

F483 

Servo: Unrecovered Measure Asymmetry SDM Failure 

F484 

Servo: Unrecovered Measure Overwrite SDM Failure 

F485 

Servo: Unrecovered TFC Utility SDM Failure 

1486 

Servo: Recovered Milli-Calibration Error 

F487 

Servo: Unrecovered Milli-Calibration Error 

F488 

Servo: Unrecovered SIDSAT Timeout Error 

F489 

Servo: Unrecovered SDM Load-And-Drop-Anchor Error 

F48A 

Servo: Unrecovered Filter Table Full Error 

F48B 

Servo: Unrecovered Filter Table Invalid Error 

148C 

Servo: Recovered Measure Qsamp SDM Failure 

F48D 

Servo: Unrecovered Measure Qsamp SDM Failure 



F501 

Host Interface: Logical unit not ready 

F502 

Host Interface: Logical unit becoming ready 

F503 

Host Interface: Logical unit not ready - initializing command required 

F504 

Host Interface: Not ready - format in progress 

F505 

Host Interface: Not ready - self-test in progress 

F506 

Host Interface: Reassign failed 

F507 

Host Interface: Format failed 

F508 

Host Interface: Not Ready - Session opened 

F509 

Host Interface: In Self-Test - Band locked 

F50B 

Host Interface: Not Ready - Sanitize in progress 

F50C 

Host Interface: Sanitize Command failed 

F50D 

Host Interface: Phy Test Function in Progress 

F511 

Host Interface: Illegal Request Sequence Error 

F512 

Host Interface: Invalid Message 

F514 

Host Interface: Not ready to ready transition 

F516 

Host Interface: Power on reset 

F517 

Host Interface: SAS Hard Reset (SAS) 

F518 

Host Interface: LUN Reset (SAS) 

F519 

Host Interface: Self initiated reset 

F51C 

Host Interface: Mode parameters changed 

F51D 

Host Interface: Log parameters changed 

F51E 

Host Interface: Reservations pre-empted 

F51F 

Host Interface: Reservations released 

F520 

Host Interface: Registrations pre-empted 
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F521 

Host Interface 

Commands cleared by another initiator 

F522 

Host Interface 

Microcode changed 

F524 

Host Interface 

Capacity Data Changed 

F52D 

Host Interface 

Buffer CRC error on read 

F52E 

Host Interface 

Internal target failure 

F534 

Host Interface 

Overlapped command attempted 

F535 

Host Interface 

Miscompare during verify 

F536 

Host Interface 

Reservation conflict 

F537 

Host Interface 

Device identifier changed 

F53E 

Host Interface 

Data phase error 

F53F 

Host Interface 

Abort by OOB (SAS) 

F544 

Host Interface 

Echo buffer overwritten 

F549 

Host Interface 

LA Check error 

F54A 

Host Interface 

Xfer Ready credit exceeded 

F54B 

Host Interface 

Transfer length error 

F54C 

Host Interface 

LUN Not Ready - Super Certify in Progress 

F54D 

Host Interface 

Super Certify Logic Error 

F54E 

Host Interface 

Data Phase CRC Error 

F550 

Host Interface 

NAK rcvd (SAS) 

F551 

Host Interface 

ACK NAK Timeout (SAS) 

F552 

Host Interface 

Bad parameter offset (SAS) 

F553 

Host Interface 

LUN Not ready, Notify (Enable Spinup) required (SAS) 

F554 

Host Interface 

l_T_Nexus Loss Occurred (SAS) 

F555 

Host Interface 

Initiator Response Timeout (SAS) 

F560 

Host Interface 

Too much write data (SAS) 

F561 

Host Interface 

Information unit too short (SAS) 

F562 

Host Interface 

Information unit too long (SAS) 

F567 

Host Interface 

Insufficient registration resources 

F568 

Host Interface 

End-to-End Data Protection Guard check 

F569 

Host Interface 

End-to-End Data Protection Application Tag check 

F56A 

Host Interface 

End-to-End Data Protection Reference Tag check 

F56B 

Host Interface 

ECC error in DRAM customer data area 

F56C 

Host Interface 

Uncorrectable DRAM ECC error 

F56F 

Host Interface 

Log dump data memory error 

F570 

Host Interface 

Host interface Synchronous CRC error 

F572 

Host Interface 

LUN not ready; manual intervention required 

F573 

Host Interface 

Commands cleared due to power failure event (SAS) 

F579 

Host Interface 

Data Checksum Error 

F57A 

Host Interface 

Synchronous CRC Error on Write 

F57B 

Host Interface 

Synchronous CRC LBA Error 

F57D 

Host Interface 

Break Received (SAS only) 



1601 

Channel/AE: Recovered Internal Logic Error 
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F602 

Channel/AE: Unrecovered Internal Logic Error 

F603 

Channel/AE: Unrecovered Internal Target Failure 

F604 

Channel/AE: Unrecovered Internal Calibration Error 

F605 

Channel/AE: Unrecovered Internal MR Calibration Error 

1606 

AE: Recovered AE Last Data Read Error 

F607 

Channel/AE: Unrecovered data with PPM or precomp load 

F608 

Channel/AE: Unrecovered Invalid SAT Sector Length Error 

1609 

AE: Recovered TFC Short Error 

F60A 

AE: TFC Short Error 

160B 

AE: Recovered Shorted MR Element Error 

F60C 

AE: Unrecovered Shorted MR Element Error 

F60D 

Unsupported Read Channel Command Error 

F60E 

Init: RRCIk Dead Error 

F60F 

Init: RRCIk Unlock Error 

1610 

AE: Recovered ECS Shorted Fault 

F611 

AE: Unrecovered ECS Shorted Fault 

1612 

AE: Recovered ECS Open Fault 

F613 

AE: Unrecovered ECS Open Fault 

1614 

AE: Recovered ECS Fault 

F615 

AE: Unrecovered ECS Fault 

1616 

Channel: Recovered Channel Error 

F617 

Channel: Unrecovered Channel Error 

1618 

AE: Recovered AE Thermal Asperity Found Error 

F619 

AE: Unrecovered AE Thermal Asperity Found Error 

161A 

AE: Recovered Open MR Element Error 

F61B 

AE: Unrecovered Open MR Element Error 

161C 

AE: Recovered 1C Over Temperature Error 

F61D 

AE: Unrecovered 1C Over Temperature Error 

161E 

AE: Recovered IP Clock Count Error 

F61F 

AE: Unrecovered IP Clock Count Error 

1620 

AE: Recovered High MR Current Error 

F621 

AE: Unrecovered High MR Current Error 

1622 

AE: Recovered Write Data BLS Error 

F623 

AE: Unrecovered Write Data BLS Error 

1624 

AE: Recovered Invalid Head Address Error 

F625 

AE: Unrecovered Invalid Head Address Error 

1626 

AE: Recovered Power Supply Error 

F627 

AE: Unrecovered Power Supply Error 

1628 

AE: Recovered Open Write Head Error 

F629 

AE: Unrecovered Open Write Head Error 

162A 

AE: Recovered Write Transition Error 

F62B 

AE: Unrecovered Write Transition Error 

162C 

AE: Recovered No Write Head Current Error 
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F62D 

AE: Unrecovered No Write Head Current Error 

162E 

Channel: Recovered Channel NRZ Clear Timeout Error 

F62F 

Channel: Unrecovered Channel NRZ Clear Timeout Error 

1630 

AE: Recovered SPE Low In Write Fault 

F631 

AE: Unrecovered SPE Low In Write Fault 

F633 

Channel: Unrecovered Write Synth Unlock error 

1634 

AE: Recovered Short Write Read Head Error 

F635 

AE: Unrecovered Short Write Read Head Error 

1636 

AE: Recovered Short Write Head Error 

F637 

AE: Unrecovered Short Write Head Error 

1638 

AE: Recovered Non-Selected Write Head Error 

F639 

AE: Unrecovered Non-Selected Write Head Error 

163A 

AE: Recovered Write Current In Read Error 

F63B 

AE: Unrecovered Write Current In Read Error 

163C 

AE: Recovered TFC Open Error 

F63D 

AE: Unrecovered TFC Open Error 

163E 

AE: Recovered IH Delay Error 

F63F 

AE: Unrecovered IH Delay Error 

1640 

AE: Recovered Write Head Encode Error 

F641 

AE: Unrecovered Write Head Encode Error 

1642 

AE: Recovered Read back Error 

F643 

AE: Unrecovered Read back Error 

1644 

AE: Recovered Latch Fault Error 

F645 

AE: Unrecovered Latch Fault Error 

1646 

AE: Recovered Write Gate During Idle Fault 

F647 

AE: Unrecovered Write Gate During Idle Fault 

1648 

Channel: Recovered Reset Flag Error 

F649 

Channel: Unrecovered Reset Flag Error 

164A 

Channel: Recovered Split Fault Error 

F64B 

Channel: Unrecovered Split Fault Error 

164C 

Channel: Recovered Sector Size Fault Error 

F64D 

Channel: Unrecovered Sector Size Fault Error 

164E 

Channel: Recovered Last Split Fault Error 

F64F 

Channel: Unrecovered Last Split Fault Error 

1650 

Channel: Recovered Servo-Servo Overlap Error 

F651 

Channel: Unrecovered Servo-Servo Overlap Error 

1652 

Channel: Recovered Read Gate Fault Error 

F653 

Channel: Unrecovered Read Gate Fault Error 

1654 

Channel: Recovered RWBI Out Fault Error 

F655 

Channel: Unrecovered RWBI Out Fault Error 

1656 

Channel: Recovered No Write Clock Error 

F657 

Channel: Unrecovered No Write Clock Error 

1658 

Channel: Recovered No NRZ Clock Error 
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F659 

Channel 

Unrecovered No NRZ Clock Error 

165A 

Channel 

Recovered Calibration Block Fault Error 

F65B 

Channel 

Unrecovered Calibration Block Fault Error 

165C 

Channel 

Recovered Mode Overlap Fault Error 

F65D 

Channel 

Unrecovered Mode Overlap Fault Error 

165E 

Channel 

Recovered Preamble Fault Error 

F65F 

Channel 

Unrecovered Preamble Fault Error 

1660 

Channel 

Recovered WPLO Fault Error 

F661 

Channel 

Unrecovered WPLO Fault Error 

1662 

Channel 

Recovered Write Gate Overlap Fault Error 

F663 

Channel 

Unrecovered Write Gate Overlap Fault Error 

1664 

Channel 

Recovered Write Gate Fault Error 

F665 

Channel 

Unrecovered Write Gate Fault Error 

1666 

Channel 

Recovered Buffer Overflow Write Error 

F667 

Channel 

Unrecovered Buffer Overflow Write Error 

1668 

Channel 

Recovered Buffer Underflow Write Error 

F669 

Channel 

Unrecovered Buffer Underflow Write Error 

166A 

Channel 

Recovered Write Parity Error 

F66B 

Channel 

Unrecovered Write Parity Error 

166C 

Channel 

Recovered Buffer Overflow Read Error 

F66D 

Channel 

Unrecovered Buffer Overflow Read Error 

166E 

Channel 

Recovered Buffer Underflow Read Error 

F66F 

Channel 

Unrecovered Buffer Underflow Read Error 

1670 

Channel 

Recovered RPLO Late Error 

F671 

Channel 

Unrecovered RPLO Late Error 

1672 

Channel 

Recovered Bit Count Late Error 

F673 

Channel 

Unrecovered Bit Count Late Error 

1674 

Channel 

Recovered Preamp Count Fault Error 

F675 

Channel 

Unrecovered Preamp Count Fault Error 

1676 

Channel 

Recovered Pfault Read Error 

F677 

Channel 

Unrecovered Pfault Read Error 

1678 

Channel 

Recovered Pfault Write Error 

F679 

Channel 

Unrecovered Pfault Write Error 

167A 

Channel 

Recovered Last Data Fault Error 

F67B 

Channel 

Unrecovered Last Data Fault Error 

167C 

Channel 

Recovered WRPO Fault Error 

F67D 

Channel 

Unrecovered WRPO Fault Error 

167E 

Channel 

Recovered Forced Channel Fault Error 

F67F 

Channel 

Unrecovered Forced Channel Fault Error 

1680 

Channel 

Recovered PLLFIoor Error 

F681 

Channel 

Unrecovered PLLFIoor Error 

1682 

Channel 

Recovered Loss lock Error 

F683 

Channel 

Unrecovered Loss lock Error 
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1684 

Channel: Recovered VGA Floor Error 

F685 

Channel: Unrecovered VGA Floor Error 

1686 

Channel: Recovered Buffer EVGA Floor Error 

F687 

Channel: Unrecovered Buffer EVGA Floor Error 

1688 

Channel: Recovered TA Detector Error 

F689 

Channel: Unrecovered TA Detector Error 

168A 

Channel: Recovered NPLD Error 

F68B 

Channel: Unrecovered NPLD Error 

168C 

Channel: Recovered ZGR Flag Error 

F68D 

Channel: Unrecovered ZGR Flag Error 

168E 

Channel: Recovered DPLL Freq Flag Error 

F68F 

Channel: Recovered DPLL Freq Flag Error 

1690 

Channel: Recovered MDO Detection Error 

F691 

Channel: Unrecovered MDO Detection Error 

1692 

Channel: Recovered TAEP Flag Error 

F693 

Channel: Unrecovered TAEP Flag Error 

1694 

Channel: Recovered Flaw Signal Sync Error 

F695 

Channel: Unrecovered Flaw Signal Sync Error 

1696 

Channel: Recovered ACQ Flag Error 

F697 

Channel: Unrecovered ACQ Flag Error 

1698 

Channel: Recovered No Clock Error 

F699 

Channel: Unrecovered No Clock Error 

169A 

Channel: Recovered PLL Loss lock Error 

F69B 

Channel: Unrecovered PLL Loss lock Error 

169C 

Channel: Recovered ESNR Timeout Error 

F69D 

Channel: Unrecovered ESNR Timeout Error 

169E 

Channel: Recovered ADC Sample Not Ready Error 

F69F 

Channel: Unrecovered ADC Sample Not Ready Error 

F6A0 

AE: Unrecovered Fuse Load Fail Error 

F6A1 

AE: Unrecovered Configuration Error 

16A2 

Channel: Recovered Auto RST NRZ-Clock Error 

F6A3 

Channel: Unrecovered Auto RST NRZ-Clock Error 

16A4 

Channel: Recovered Write CRC Fault Error 

F6A5 

Channel: Unrecovered Write CRC Fault Error 

16A6 

Channel: Recovered Synchronous Loss Lock Error 

F6A7 

Channel: Unrecovered Synchronous Loss Lock Error 

16A8 

Channel: Recovered RLL Parameter Error 

F6A9 

Channel: Unrecovered RLL Parameter Error 

16AA 

Channel: Recovered FIFO Underflow Error 

F6AB 

Channel: Unrecovered FIFO Underflow Error 

16AC 

Channel: Recovered FIFO Overflow Error 

F6AD 

Channel: Unrecovered FIFO Overflow Error 

16AE 

Channel: Recovered Iterative Decoder Error 
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F6AF 

Channel: Unrecovered Iterative Decoder Error 

16B0 

Channel: Recovered Iterative Read Error 

F6B1 

Channel: Unrecovered Iterative Read Error 

16B2 

Channel: Recovered Encoder Overflow Error 

F6B3 

Channel: Unrecovered Encoder Overflow Error 

16B4 

Channel: Recovered Encoder Underflow Error 

F6B5 

Channel: Unrecovered Encoder Underflow Error 

16B6 

Channel: Recovered Encoder RAM CRC Error 

F6B7 

Channel: Unrecovered Encoder RAM CRC Error 

16B8 

Channel: Recovered Interface Fault 

F6B9 

Channel: Unrecovered Interface Fault 

16BA 

Channel: Recovered QMM EVDump Parse Error 

F6BB 

Channel: Unrecovered QMM EVDump Parse Error 

16BC 

Channel: Recovered DiBit Timeout Error 

F6BD 

Channel: Unrecovered DiBit Timeout Error 

F6BE 

Channel: Unrecovered Insufficient TFC Heat Error 

16C0 

Channel: Recovered Data Jam Error 

F6C1 

Channel: Unrecovered Data Jam Error 

16C2 

Channel: Recovered Code-Word Out Of Order Error 

F6C3 

Channel: Unrecovered Code-Word Out Of Order Error 

F6C4 

AEQ: Timeout Error 

F6C5 

AEQ: NLD Initialization Timeout Error 

F6C6 

Channel: Unrecovered ADC Calibration Timeout Error 

F6C7 

Channel: Unrecovered ADC Buffer Calibration Timeout Error 

F6C8 

Channel: Unrecovered Power Sequence Timeout Error 



F701 

Format corrupted 

F702 

Too many notches 

D703 

Media: Auto Reallocated Write Error 

1704 

Media: Recovered Write Error - Recommend reassign 

D705 

Media: Error With OTF Correction - Reassigned 

E706 

Media: Error With OTF Correction - Recommend Reassign 

E707 

Media: Error With OTF Correction - Recommend Rewrite 

E708 

Media: Error With OTF Correction - Rewritten 

1709 

Media: Recovered Error With Offline Correction 

D70A 

Media: Error With Offline Correction - Reassigned 

E70B 

Media: Error With Offline Correction - Recommend Reassign 

E70C 

Media: Error With Offline Correction - Recommend Rewrite 

E70D 

Media: Error With Offline Correction - Rewritten 

E70E 

Media: Recovered Data Address Mark Error - Rewritten 

E70F 

Media: Recovered Data Address Mark Error - Recommend Rewrite 

D710 

Media: Recovered Data Address Mark Error - Reassigned 

E711 

Media: Recovered Data Address Mark Error - Recommend Reassign 
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1712 

Media: Recovered LBA MEDC Error 

F713 

Media: Unrecovered LBA MEDC Error 

1714 

Media: Recovered Sector Overflow Error 

F715 

Media: Unrecovered Sector Overflow Error 

1716 

Media: Recovered Write Overrun Error 

F717 

Media: Unrecovered Write Overrun Error 

171C 

Media: Recovered DRAM CRC Error 

F71D 

Media: Unrecovered DRAM CRC Error 

172C 

Media: Recovered Data 

F72D 

Media: Unrecovered Uncorrectable Read Data error 

172E 

Media: Recovered Error on Last Data Read 

F72F 

Media: Unrecovered Error on Last Data Read 

F730 

Media: Recommend targeted scan 

1731 

Media: Recovered Write Fault 

F732 

Media: Unrecovered Write Fault 

1733 

Media: Recovered Read Write Abort Error 

F734 

Media: Unrecovered Read Write Abort Error 

1735 

Channel: Recovered No Sync Detected Error 

F736 

Channel: Unrecovered No Sync Detected Error 

1737 

Media: Recovered Post Write Abort Error 

F738 

Media: Un recove red Post Write Abort 

1739 

Media: Recovered Post PES Check Write Abort Error 

F73A 

Media: Unrecovered Post PES Check Write Abort Error 

173B 

Media: Recovered Data Address Mark Error 

F73C 

Media: Unrecovered Data Address Mark Error 

173D 

Media: Recovered Sector Miss Error 

F73E 

Media: Unrecovered Sector Miss Error 

F741 

Media: OCT Timeout Not Dispatched 

F742 

Media: OCT Timeout In Recovery 

F743 

Media: OCT Timeout Executing 

1744 

Media: Recovered Sudden Stop Error 

F745 

Media: Unrecovered Sudden Stop Error 

1746 

Media: Recovered Defect List Format Not Supported Error 

1747 

Media: Recovered Primary Defect List Not Found Error 

1748 

Media: Recovered Grown Defect List Not Found Error 

1749 

Media: Recovered Partial Defect List Transferred Error 

F74A 

Media: Unrecovered Alternate Track Table Full Error 

F74B 

Media: Unrecovered Primary Defect List Error 

F74C 

Media: Unrecovered Grown Defect List Error 

F74D 

Media: Unrecovered Too Many Heads Error 

F74E 

Media: Unrecovered Skew Table Size Error 

F74F 

Media: Unrecovered Too Many Zones Error 

F750 

Media: Unrecovered Too Many SIDs Error 
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F751 

Media: Unrecovered Alternate Track Table Full Error 

F752 

Media: Unrecovered Drive Capacity Too Small 

F753 

Media: Unrecovered G-list Full (Format command) 

F754 

Media: Unrecovered G-list Full (2) (Format command) 

F755 

Media: Unrecovered Pointer Repeat Size Error 

F756 

Media: Unrecovered DST Slot Size Error 

F757 

Media: Unrecovered P-list Full Error 

F758 

Media: Unrecovered Spare List Full Error 

1759 

Media: Recovered Unknown Error 

F75A 

Media: Unrecovered Unknown Error 

F75B 

Media: Unrecovered Too Many Sectors Error 

F75C 

Media: Unrecovered Internal Media Access Timeout Error 

F75D 

Media: Unrecovered Self-Test Failed Error 

F75E 

Media: Unrecovered Maximum Servo Cylinder Number Too Small Error 

F75F 

Media: Unrecovered SAT No Buffer Overflow Error 

F760 

Media: Unrecovered SAT Buffer Overflow Error 

F762 

Media: Unrecovered Self-Test Hard-Cache Test Fail 

F763 

Media: Unrecovered Self-Test OTF-Cache Fail 

1766 

Channel: Recovered XTS LOAD Timeout Error 

F767 

Channel: Unrecovered XTS LOAD Timeout Error 

1768 

Media: Recovered Key Seed ID Mismatch Error 

F769 

Media: Unrecovered Key Seed ID Mismatch Error 

176A 

Media: Recovered No NRZ Clock Error 

F76B 

Media: Unrecovered No NRZ Clock Error 

176C 

Media: Recovered MEDC Correctable Error 

F76D 

Media: Unrecovered MEDC Uncorrectable Error 

176E 

Media: Correctable Channel Ready Error 

F76F 

Media: Uncorrectable Channel Ready Error 

1770 

Media: Recovered SID Timeout Error 

F771 

Media: Unrecovered SID Timeout Error 

F772 

Media: Unrecovered DASH starting timeout 

F773 

Media: Unrecovered ID table timeout 

F774 

Media: Unrecovered Servo timeout 

F775 

Media: Unrecovered Buffers timeout 

F776 

Media: Unrecovered DASH done timeout 

F777 

Media: Unrecovered DASH unknown timeout 

F77B 

Media: Unrecovered Abort EOS fail 

F77E 

Media: Write Error Recovery Timeout 

F77F 

Media: Read Error Recovery Timeout 

1782 

Media: Recovered Force Soft Error 

F783 

Media: Unrecovered Force Soft Error 

1784 

Media: Recovered Channel Sector Marginal Error 

F785 

Media: Unrecovered Channel Sector Marginal Error 
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1786 

Media 

Recovered LLI Underrun Error 

F787 

Media 

Unrecovered LLI Underrun Error 

F78E 

Media 

Unrecovered SAT No Buffer Overflow With ECS Fault 

F78F 

Media 

Unrecovered SAT Buffer Overflow With ECS Fault 

1792 

Media 

Recovered MEDC Write Data Not Ready Error 

F793 

Media 

Unrecovered MEDC Write Data Not Ready error 

1794 

Media 

Recovered DMA Timeout Error 

F795 

Media 

Unrecovered DMA Timeout Error 

F797 

Media 

SAT Write Abort 

1798 

Media 

Recovered ID Not Found Error 

F799 

Media 

Unrecovered ID Not Found Error 

179C 

Media 

Recovered Channel Read Timeout Error 

F79D 

Media 

Unrecovered Channel Read Timeout Error 

17A9 

Media 

Recovered Read Overrun Error 

F7AA 

Media 

Unrecovered Read Overrun Error 

F7AC 

Media 

Unrecovered Super Certification Log Write Error 

F7AD 

Media 

Unrecovered Super Certification Log Read Error 

17AE 

Media 

Recovered ECC Correctable Error 

F7AF 

Media 

Unrecovered Sector Missing Error 

F7B0 

Media 

Unrecovered Sector Overflow 

17B2 

Media 

Recovered Abort Window Error 

F7B3 

Media 

Unrecovered Abort Window Error 

17B4 

Media 

Recovered Shock Sensor Error 

F7B5 

Media 

Unrecovered Shock Sensor Error 

17B8 

Media 

Recovered Reference Tag Error 

F7B9 

Media 

Unrecovered Reference Tag error 

17BA 

Media 

Recovered Application Tag Error 

F7BB 

Media 

Unrecovered Application Tag Error 

17BC 

Media 

Recovered Gourd Check Error 

F7BD 

Media 

Unrecovered Guard Check Error 

17C0 

Media 

Recovered End Sector Check Error 

F7C1 

Media 

Unrecovered End Sector Check Error 

17C2 

Media 

Recovered Read CRC Error 

F7C3 

Media 

Unrecovered Read CRC Error 

17C4 

Media 

Recovered DRAM ECC Error 

F7C5 

Media 

Unrecovered DRAM ECC Error 

17C6 

Media 

Recovered DRAM ECC LBA Error 

F7C7 

Media 

Unrecovered DRAM ECC LBA Error 

F7CA 

Media 

Unrecovered LBA Correction Disabled Error 

17CB 

Media 

Recovered LBA Write Correctable Error 

F7CC 

Media 

Unrecovered LBA Write Uncorrectable Error 

F7CD 

Media 

Unrecovered LBA Encryption Error 

F7CE 

Media 

Unrecovered Offline Already TAR Error 
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F7D0 

Media 

Unrecovered Pre-load Timeout Error 

17D4 

Media 

Recovered Parity PTR FIFO Error 

F7D5 

Media 

Unrecovered Parity PTR FIFO Error 

17D6 

Media 

Recovered Parity LBA FIFO Error 

F7D7 

Media 

Unrecovered Parity LBA FIFO Error 

17D8 

Media 

Recovered Parity Uncorrectable FIFO Error 

F7D9 

Media 

Unrecovered Parity Uncorrectable FIFO Error 

17DA 

Media 

Recovered Status Uncorrectable FIFO Error 

F7DB 

Media 

Unrecovered Status Uncorrectable FIFO Error 

17DC 

Media 

Recovered Parity EDC SRAM Error 

F7DD 

Media 

Unrecovered Parity EDC SRAM Error 

17DE 

Media 

Recovered REQ/ACK Handshake Error 

F7DF 

Media 

Unrecovered REQ/ACK Handshake Error 

17E0 

Media 

Recovered Write Splice Error 

F7E1 

Media 

Unrecovered Write Splice Error 

17E2 

Media 

Recovered Read Parity Error 

F7E3 

Media 

Unrecovered Read Parity Error 

17E4 

Media 

Recovered EPO Error 

F7E5 

Media 

Unrecovered EPO Error 

17E6 

Media 

Recovered NRZ Sector Marginal Error 

F7E7 

Media 

Unrecovered NRZ Sector Marginal Error 

17E8 

Media 

Recovered AE Access Inhibit Error 

F7E9 

Media 

Unrecovered AE Access Inhibit Error 

17EA 

Media 

Recovered PTR FIFO Error 

F7EB 

Media 

Unrecovered PTR FIFO Error 

17EC 

Media 

Recovered LBA FIFO Error 

F7ED 

Media 

Unrecovered LBA FIFO Error 

17EE 

Media 

Recovered Sector Number Cylinder Error 

F7EF 

Media 

Unrecovered Sector Number Cylinder Error 

17F0 

Media 

Recovered Read Transfer Length Error 

F7F1 

Media 

Unrecovered Read Transfer Length Error 

17F2 

Media 

Recovered DS RDC Burst Error 

F7F3 

Media 

Unrecovered DS RDC Burst Error 

17F4 

Media 

Recovered SV RDC Burst Error 

F7F5 

Media 

Unrecovered SV RDC Burst Error 



F813 

CMD: Insufficient Buffer Space Error 

F820 

CMD: Unrecovered Parameter List Length Error 

F821 

CMD: Unrecovered Invalid Opcode in CDB Error 

F822 

CMD: Unrecovered LBA Out Of Range Error 

F823 

CMD: Unrecovered Invalid Field In CDB Error 

F824 

CMD: Unrecovered Invalid LUN Error 

F825 

CMD: Unrecovered Invalid Field In Parameter List Error 
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F826 

CMD: Unrecovered Unsupported Log Page Error 

F827 

CMD: Un recove red Access Denied Error 

F828 

CMD: Unrecovered Invalid Release of Persistent Reservation Error 

F830 

CMD: Unrecovered Sequence Error 

1831 

CMD: Power Mode Idle_A By Timer 

1832 

CMD: Power Mode ldle_B By Timer 

1833 

CMD: Power Mode ldle_C By Timer 

1834 

CMD: Power Mode Standby_Z By Timer 

1835 

CMD: Power Mode Idle_A By Command 

1836 

CMD: Power Mode ldle_B By Command 

1837 

CMD: Power Mode ldle_C By Command 

1838 

CMD: Power Mode Standby_Z By Command 

1839 

CMD: Power Mode Standby_Y By Timer 

183 A 

CMD: Power Mode Standby_Y By Command 



1A02 

SMART: Temperature Warning (No Sense) 

2A02 

SMART: Temperature Warning (Recovered Sense) 

3A02 

SMART: Temperature Warning (Unit Attention) 

1A03 

SMART: Background Self-Test Failure (No Sense) 

2A03 

SMART: Background Self-Test Failure (Recovered Sense) 

3A03 

SMART: Background Self-Test Failure (Unit Attention) 

1A04 

SMART: Background Pre-Scan Failure (No Sense) 

2A04 

SMART: Background Pre-Scan Failure (Recovered Sense) 

3A04 

SMART: Background Pre-Scan Failure (Unit Attention) 

1A05 

SMART: Background Media Scan Failure (No Sense) 

2A05 

SMART: Background Media Scan Failure (Recovered Sense) 

3A05 

SMART: Background Media Scan Failure (Unit Attention) 

1A14 

SMART: Spare Sector Availability Warning (No Sense) 

2A14 

SMART: Spare Sector Availability Warning (Recovered Sense) 

3A14 

SMART: Spare Sector Availability Warning (Unit Attention) 

1A21 

SMART: Milli-Actuator Error (No Sense) 

2A21 

SMART: Milli-Actuator Error (Recovered Sense) 

3A21 

SMART: Milli-Actuator Error (Unit Attention) 

1A22 

SMART: Extreme Over-Temperature Warning (No Sense) 

2A22 

SMART: Extreme Over-Temperature Warning (Recovered Sense) 

3A22 

SMART: Extreme Over-Temperature Warning (Unit Attention) 

1A32 

SMART: Read Error Rate Warning (No Sense) 

2A32 

SMART: Read Error Rate Warning (Recovered Sense) 

3A32 

SMART: Read Error Rate Warning (Unit Attention) 

1A43 

SMART: Seek Error Rate Warning (No Sense) 

2A43 

SMART: Seek Error Rate Warning (Recovered Sense) 

3A43 

SMART: Seek Error Rate Warning (Unit Attention) 

1A4A 

SMART: Write Error Rate Warning (No Sense) 
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2A4A 

SMART: Write Error Rate Warning (Recovered Sense) 

3A4A 

SMART: Write Error Rate Warning (Unit Attention) 

1A50 

SMART: Load/Unload Cycle Count Warning (No Sense) 

2A50 

SMART: Load/Unload Cycle Count Warning (Recovered Sense) 

3A50 

SMART: Load/Unload Cycle Count Warning (Unit Attention) 

1A56 

SMART: Spinup Time Warning (No Sense) 

2A56 

SMART: Spinup Time Warning (Recovered Sense) 

3A56 

SMART: Spinup Time Warning (Unit Attention) 

1A5B 

SMART: Spinup Retry Count Warning (No Sense) 

2A5B 

SMART: Spinup Retry Count Warning (Recovered Sense) 

3A5B 

SMART: Spinup Retry Count Warning (Unit Attention) 

FA81 

Self-Test: Unrecoverable Error Count Threshold Exceeded 

2A83 

Self-Test: GUST Error Count Threshold Reached 

1A85 

Self-Test: Recovery Error 

2A85 

Self-Test: Servo Error 

4A85 

Self-Test: Command Timeout Error 

FA85 

Self-Test: Unrecoverable Error 



FCxx 

Media: Unrecovered Unable to Read RID or FID Number xx 



1ED6 

Media: Recovered R/W Abort Off Track Write Error 

FED7 

Media: Unrecovered R/W Abort Off Track Write Error 

1ED8 

Media: Recovered R/W Abort RRO Field Misread Error 

FED9 

Media: Unrecovered R/W Abort RRO Field Misread Error 

1 EDA 

Media: Recovered R/W Abort RRO Field Missing Error 

FEDB 

Media: Unrecovered R/W Abort RRO Field Missing Error 

1EDC 

Media: Recovered R/W Abort Idle Seek Error 

FEDD 

Media: Unrecovered R/W Abort Idle Seek Error 

1 EDE 

Media: Recovered R/W Abort Seek Timeout Error 

FEDF 

Media: Unrecovered R/W Abort Seek Timeout Error 

1EEO 

Media: Recovered R/W Abort Estimator Error 

FEE1 

Media: Unrecovered R/W Abort Estimator Error 

1EE2 

Media: Recovered R/W Abort Predictor Error 

FEE3 

Media: Unrecovered R/W Abort Predictor Error 

1 EE4 

Media: Recovered R/W Abort PES Error 

FEE5 

Media: Unrecovered R/W Abort PES Error 

1EE6 

Media: Recovered R/W Abort Seek Start Error 

FEE7 

Media: Unrecovered R/W Abort Seek Start Error 

1EE8 

Media: Recovered R/W Abort PES Reset Error 

FEE9 

Media: Unrecovered R/W Abort PES Reset Error 

1 EEA 

Media: Recovered R/W Abort SID Unlock Error 

FEEB 

Media: Unrecovered R/W Abort SID Unlock Error 

1 EEC 

Media: Recovered R/W Abort WCS Error 
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FEED 

Media: Unrecovered R/W Abort WCS Error 

IEEE 

Media: Recovered R/W Abort Hard Reset Error 

FEEF 

Media: Unrecovered R/W Abort Hard Reset Error 

1EFO 

Media: Recovered R/W Abort Shock Error 

FEF1 

Media: Unrecovered R/W Abort Shock Error 

1EF2 

Media: Recovered R/W Abort Unlock Macro Error 

FEF3 

Media: Unrecovered R/W Abort Unlock Macro Error 

1 EF4 

Media: Recovered R/W Abort Sharp Error 

FEF5 

Media: Unrecovered R/W Abort Sharp Error 

1EF6 

Media: Recovered R/W Abort Aggressive Error 

FEF7 

Media: Unrecovered R/W Abort Aggressive Error 

1EF8 

Media: Recovered R/W Abort SVGA Limit Error 

FEF9 

Media: Unrecovered R/W Abort SVGA Limit Error 

1 EFA 

Media: Recovered R/W Abort Gray Code Error 

FEFB 

Media: Un recove red R/W Abort Gray Code Error 

1EFC 

Media: Recovered R/W Abort Burst Error 

FEFD 

Media: Unrecovered R/W Abort Burst Error 

1EFE 

Media: Recovered R/W Abort No STM Error 

FEFF 

Media: Unrecovered R/W Abort No STM Error 
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